今天在网上找到了一本非常好的书:《Ext江湖》,这本书是由大漠穷秋大神写的,刚看到这本书的时候,心里面的那个激动劲啊,本来原先的时候心里面就一直念叨着想要学习Ext,但是苦于找不到好的资料。现在就好像发现了新大陆一样,于是我马上就把他download下来,不到半个小时,我开始犯迷糊了,对于我这样一个刚接触javascript差不多半年的人来说,看着里面写的有些地方还有点困难,怎么可以呢!!!是吧。但是事实就是这样,自己也不能放弃,大不了就多花点时间吗,多大点事情儿。可怜我后面又要长时间的处于Ext的煎熬之中了,诶,不说了,开始今天的学习。

第一章:变量、对象、数组

这些都还是比较基础的东西,就不多花时间去记录了。但是这里还是有一个Ext.apply()。

var p1={name:'李四',age:22};
var p2={};
Ext.apply(p2,p1);
console.log(p2);

第二章:关于DOM

DOM(document object model)文档对象模型,每次写一个网页的时候,关于DOM的东西都是写的非常多的。但是最基础的莫过于访问HTML节点,这里面包括的方法就多了。原生的方法主要有什么:document.getElementById()这个想必也是大家最经常用到的,还有document.getElementsByTagName(),document.getElementsByClassName(),document.getElementsByName()等等还是有那么几个的,这里我就不一一列举了,但是对于我个人喜欢用的还是要说下document.querySelector(),document.querySelectorAll(),这里说道Ext,就先要说下Ext.get(),Ext.fly(),Ext.getDom()等这几个方法。

<div id="myDiv">我有一只小毛驴,我从来也不骑。</div>
<button id="btn">click me</button>
<div id="wel" style="width: 100px;height: 100px;">我来到你的城市</div>
<script>
var el=Ext.getDom('myDiv');
console.log(el);
el=Ext.get('myDiv');
console.log(el);
console.log(el.dom);
el=Ext.fly('myDiv');
console.log(el);
Ext.get('btn').on({'click':function(){
el.setStyle('backgroundColor','gray');
el.highlight();
}
});
</script>

这里的Ext.get(),Ext.fly(),Ext.getDom()三者返回的分别是Element对象、Element对象还有DOM对象。然后Element对象可以通过el.dom转换为DOM对象,DOM对象可以通过Ext.get(d)转换为Element对象。

var d=document.getElementById('myDiv');
var e=Ext.get(d);
console.log(d); //DOM对象
console.log(Ext.get(d)); //Ext.Element对象
console.log(Ext.get(d).dom); //DOM对象
console.log(Ext.get(['myDiv','wel'])); //可以给Ext.get()传递一个数组,Ext.get()会把这个数组里面的元素当成CSS选择器,然后利用这些选择器去查找元素

关于Ext.get(),Ext.fly()这两个呢,首先他们返回的结果中Ext.get()是含有id属性的,而Ext.fly()这个并没有。

  这个是Ext.get()返回的结果。

这是Ext.fly()返回的结果。

另外他们的区别主要可不是这一点点的,不然既然有了Ext.get()那为什么还会出来一个Ext.fly()呢,Ext.get()的源代码解析,可以看到,他的核心思路是"缓存机制",当多次尝试get()同一个html元素的时候,只有第一次会创建Ext.Element对象,而后续的所有get()都是从缓存EC中获取的,如果我们反复的用Ext.get()获取不同的元素,那么这个EC所占用的内存将会越来越大,所以如果我们获取一个元素仅仅只是为了进行一个比较简单的操作,后面也不会多次获取相同的元素,就不要用Ext.get()来浪费内存,所以这里又会有一个轻量级的Ext.fly()方法来获取元素。

关于Ext.DomHeper,我们可以用到的方法有Ext.DomHelper.append(),Ext.DomHelper.insertHtml()来插入元素。

先说Ext.DomHelper.append()这里有两种方法,分别是js对象方法和使用标签片段插入。

//js对象方法
var obj={
tag : 'ul',
children : [
{tag : 'li',html : '<button>关关雎鸠</button>'},
{tag : 'li',html : '<button>在河之洲</button>'},
{tag : 'li',html : '<button>窈窕淑女</button>'},
{tag : 'li',html : '<button>君子好逑</button>'}
]
}; // 使用标签片段插入
var str='<ul><li>关关雎鸠</li><li>在河之洲</li><li>窈窕淑女</li><li>君子好逑</li></ul>';
Ext.DomHelper.append('myDiv',str);
Ext.DomHelper.append('myDiv',obj);

使用Ext.DomHelper.insertHtml方法插入

var obj1={
tag : 'div',
children: [
{tag : 'a',href : '#', html : '人生若只如初见'},
{tag : 'a',href : '#', html : '何事秋风悲画扇'}
]
};
var str1='<div><a href="#">人生若只如初见</a><a href="#">何事秋风悲画扇</a></div>'
// insertHtml方法不能使用js对象方法插入,会在页面上直接显示[object Object]
Ext.DomHelper.insertHtml('beforeBegin',Ext.getDom("myDiv"),obj1);
Ext.DomHelper.insertHtml('afterBegin',Ext.getDom("myDiv"),obj1);
Ext.DomHelper.insertHtml('beforeEnd',Ext.getDom("myDiv"),str1);
Ext.DomHelper.insertHtml('afterEnd',Ext.getDom("myDiv"),str1);
//用afterEnd新插入的div就变为了myDiv的兄弟元素,不再是子节点了

这里有两点需要注意:

1、

insertHtml方法不能使用js对象方法插入,会在页面上直接显示[object Object]

2、

用afterEnd新插入的div就变为了myDiv的兄弟元素,不再是子节点了

然后关于beforeBegin、afterBegin、beforeEnd、afterEnd这四个可以这样来理解。

[位置一]<div>[位置二]这里是其他内容[位置三]</div>[位置四]

beforeBegin、afterBegin、beforeEnd、afterEnd分别对应位置一到位置四

然后关于Ext.DomHelper.overwrite(),该方法覆盖myDiv里面的所有内容,并不会吧标签也整个覆盖掉。

然后就是Ext.query()获取节点了,也没什么好说的,直接附上代码了。

console.log(Ext.query('button'));//Ext.query()是Ext.DomQuery.select的快捷方式
console.log(Ext.query('button:first-child'));//获取了文档中所有以button为第一个子元素的button
var li=Ext.query('li:even');
Ext.each(li,function(b){
b.style.background='#ff0';
});

模板覆盖:

var tpl=Ext.DomHelper.createTemplate('<li>{content}</li>');
tpl.overwrite('myDiv',{content:'劝君莫作独醒人,烂醉花间应有数'});

另外还有一个Ext.DomQuery.selectNode。

Ext.DomQuery.selectNode('div{width="100px"}').style.color='red';

Ext.DomQuery.selectNode()与Ext.getDom获得的都是DOM对象。

另外还有一个el.setStyle()可以为某个元素设置单独的样式属性值。

el.setStyle('backgroundColor','gray');

好了,今天就到这里。明天再继续。我的闯荡Ext的生涯终于前进了第一步!!!

闯荡Ext-第一篇的更多相关文章

  1. PHP 性能分析第一篇: Xhprof & Xhgui 介绍

    [前言]这是国外知名博主 Davey Shafik所撰写的 PHP 应用性能分析系列的第一篇,阅读第二篇可深入了解 xhgui,第三篇则关注于性能调优实践. 什么是性能分析? 性能分析是衡量应用程序在 ...

  2. Asp.net原理(第一篇)

    Asp.net (第一篇) 当用户在浏览器输入一个URL地址后,浏览器会发送一个请求到服务器.这时候在服务器上第一个负责处理请求的是IIS.然后IIS再根据请求的URL扩展名将请求分发给不同的ISAP ...

  3. PHP 性能分析第一篇: Intro to Xhprof & Xhgui

    [前言]这是国外知名博主 Davey Shafik所撰写的 PHP 应用性能分析系列的第一篇,阅读第二篇可深入了解 xhgui,第三篇则关注于性能调优实践. 原文链接如下: https://blog. ...

  4. 从0开始搭建SQL Server AlwaysOn 第一篇(配置域控)

    从0开始搭建SQL Server AlwaysOn 第一篇(配置域控) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www.cnb ...

  5. Python爬虫小白入门(四)PhatomJS+Selenium第一篇

    一.前言 在上一篇博文中,我们的爬虫面临着一个问题,在爬取Unsplash网站的时候,由于网站是下拉刷新,并没有分页.所以不能够通过页码获取页面的url来分别发送网络请求.我也尝试了其他方式,比如下拉 ...

  6. Three.js 第一篇:绘制一个静态的3D球体

    第一篇就画一个球体吧 首先我们知道Three.js其实是一个3D的JS引擎,其中的强大之处就在于这个JS框架并不是依托于JQUERY来写的.那么,我们在写这一篇绘制3D球体的文章的时候,应该注意哪些地 ...

  7. 深入学习jQuery选择器系列第一篇——基础选择器和层级选择器

    × 目录 [1]id选择器 [2]元素选择器 [3]类选择器[4]通配选择器[5]群组选择器[6]后代选择器[7]兄弟选择器 前面的话 选择器是jQuery的根基,在jQuery中,对事件处理.遍历D ...

  8. 【第一篇】ASP.NET MVC快速入门之数据库操作(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

  9. Android基础学习第一篇—Project目录结构

    写在前面的话: 1. 最近在自学Android,也是边看书边写一些Demo,由于知识点越来越多,脑子越来越记不清楚,所以打算写成读书笔记,供以后查看,也算是把自己学到所理解的东西写出来,献丑,如有不对 ...

随机推荐

  1. 微服务SpringCloud之服务调用与负载均衡

    上一篇我们学习了服务的注册与发现,本篇博客是在上一篇的基础上学习服务的调用.上一博客主要创建了Eureka的服务端和一个Client,该Client包含了一个Controller用来提供对外服务供外部 ...

  2. JUnit-4.13使用报java.lang.NoClassDefFoundError: org/hamcrest/SelfDescribing错误

    今天重新复习spring的时候,调用Junit架包来进行测试,进入其官网  https://junit.org/junit5/,点击右上角的Junit4进行查看 2.出现了的页面是这个样子 我把这个页 ...

  3. C# 连接数据库等

    SqlConnection连接池:可以通过连接字符串配置连接池.对象池技术:HttpApplication :Asp.Net生产者 消费者. 线程.应用程序跟数据连接非常耗时,而且连接使用非常频繁,使 ...

  4. kubernetes实战之consul篇及consul在windows下搭建consul简单测试环境

    consul是一款服务发现中间件,1.12版本后增加servicemesh功能.consul是分布式的,可扩展的,高可用的根据官方文档介绍,目前已知最大的consul集群有5000个节点,consul ...

  5. BZOJ 2115:Xor(线性基+DFS)

    题目链接 题意 中文题意 思路 因为存在环和重边,边来回走是没有意义的,因此最终的答案应该是一条从1到n的路径权值异或上若干个环的权值,那么难点在于如何选取这些环的权值使得最终的答案更优. 使用到线性 ...

  6. iOS组件化开发一使用source管理远端库升级(四)

    一.克隆远端库代码到本地选择master分支 1.克隆 2.代码会显示出你所有版本的tag 二.可以在Example目录下验证代码的正确行: cd 到库的文件夹然后 pod install comma ...

  7. C# 反射的详细理解

    网友A的解释: C# 反射机制的学习心得   首先说说,为什么要学习 反射 呢?有什么用啊. 在我们写程序的时候,经常会用到一些类中的方法,那么就要调用这些个类.如果不是在一个命名空间里时,就要引用相 ...

  8. !干货! 为设计指定输入驱动强度 set_driving_cell set_drive set_input_transition

    !干货! 为设计指定输入驱动强度 set_driving_cell set_drive set_input_transition 本文转自:自己的微信公众号<集成电路设计及EDA教程> 里 ...

  9. python爬虫笔记之re.compile.findall()

    re.compile.findall原理是理解了,但输出不大理解(主要是加了正则表达式的括号分组) 一开始不懂括号的分组及捕捉,看了网上这个例子(如下),然而好像还是说不清楚这个括号的规律(还是说我没 ...

  10. 个人永久性免费-Excel催化剂功能第77波-专业图表制作辅助之批量维护序列点颜色及数据标签

    2018年最后一天工作日完成第77波,7是代表完美,2个7,双重的完美,Excel催化剂的2018年从始至终共77波都充满着完美接近极致的功能体验.感谢各位一路相随,陪伴成长.最后一波,再次让数据分析 ...