-
"aaRoot.querySelector尽然还有返回值!因为上下文查找的范围包含了自身了。”是在说,“上下文”中包括了自己。 因为如果是$(element).find(...),这个查找上下文中,不包括element自己,而是从他的children list里面找。查看全部
-
deferred的全部接口都是用的once memory类型。每添加一个新的callback,他只会被执行一次。并且是用上次的参数。 不知道理解的对不对。。查看全部
-
1. access就是检测一下,到底是应该使用set还是get。 2. 其实真正原因还是因为实例的get方法中的owner传入的是dom对象。查看全部
-
jquery整体架构和五大块查看全部
-
array用来判断函数是不是已经add进去时,indexOf是用的reference作比较。查看全部
-
内部会划分一个新的构造器init吗?jQuery通过new原型prototype上的init方法当作构造器,那么init的原型链方法就是实例的方法了,所以jQuery通过2个构造器划分2种不同的调用方式一种是静态,一种是原型。查看全部
-
HTML <iframe> 标签 定义和用法 iframe 元素会创建包含另外一个文档的内联框架(即行内框架)。 HTML 与 XHTML 之间的差异 在 HTML 4.1 Strict DTD 和 XHTML 1.0 Strict DTD 中,不支持 iframe 元素。 您可以把需要的文本放置在 <iframe> 和 </iframe> 之间,这样就可以应对无法理解 iframe 的浏览器。查看全部
-
.end()可以返回当前dom的父节点查看全部
-
浏览器渲染原理 浏览器从下载文档到显示页面的过程是个复杂的过程这里包含了重绘和重排。各家浏览器引擎的工作原理略有差别但也有一定规则。 简单讲通常在文档初次加载时浏览器引擎会解析HTML文档来构建DOM树之后根据DOM元素的几何属性构建一棵用于渲染的树。渲染树的每个节点都有大小和边距等属性类似于盒子模型由于隐藏元素不需要显示渲染树中并不包含DOM树中隐藏的元素。 当渲染树构建完成后浏览器就可以将元素放置到正确的位置了再根据渲染树节点的样式属性绘制出页面。查看全部
-
// 1.$(document) // 2.$(‘<div>’) // 3.$(‘div’) // 4.$(‘#test’) // 5.$(function(){}) // 6.$("input:radio", document.forms[0]); // 7.$(‘input’, $(‘div’)) // 8.$() // 9.$("<div>", { // "class": "test", // text: "Click me!", // click: function(){ $(this).toggleClass("test"); } // }).appendTo("body"); // 10$($(‘.test’))查看全部
-
function when(d1, d2) { var i = 0, resolveValues = [].slice.call(arguments), length = resolveValues.length; var len = length; //收集resolve值 var values = []; var deferred = jQuery.Deferred(); function updateFunc(value) { values.push(value); if (len === 1) { deferred.resolveWith('contexts', values); } len-- } for (; i < length; i++) { resolveValues[i].done(updateFunc) } return deferred; } when(d1, d2).done(function(v1, v2) { show(v1); // "Fish" show(v2); // "Pizza" }); 没看懂查看全部
-
(function(window, undefined) { var jQuery = function() {} // ... window.jQuery = window.$ = jQuery; })(window); 从上面的代码可看出,自动初始化这个函数,让其只构建一次。详细说一下这种写法的优势: 1、window和undefined都是为了减少变量查找所经过的scope作用域。当window通过传递给闭包内部之后,在闭包内部使用它的时候,可以把它当成一个局部变量,显然比原先在window scope下查找的时候要快一些。 2、undefined也是同样的道理,其实这个undefined并不是JavaScript数据类型的undefined,而是一个普普通通的变量名。只是因为没给它传递值,它的值就是undefined,undefined并不是JavaScript的保留字。查看全部
-
其中定义了done、fail以及progress这几个方法,其实就是Callbacks回调函数中的add方法,用与push外部的的数据,保存在队列上。 我们通过resolve、reject以及notify其实也就是处理Callbacks中的队列列表。查看全部
-
我们知道,Array.prototype.slice.call(arguments)能将具有length属性的对象转成数组,除了IE下的节点集合(因为ie下的dom对象是以com对象的形式实现的,js对象与com对象不能进行转换) 如: 1 var a={length:2,0:'first',1:'second'}; 2 Array.prototype.slice.call(a);// ["first", "second"] 3 4 var a={length:2}; 5 Array.prototype.slice.call(a);// [undefined, undefined]查看全部
-
常见的异步操作: 定时器setTimeout postmessage WebWorkor CSS3 动画 XMLHttpRequest HTML5的本地数据 等等…查看全部
举报
0/150
提交
取消