jQueryInAction Reading Note 7.

jQuery插件命名规则

jquery.pluginName.js

pluginName指代的是插件的名称,如voctrals,tlaliu或者更有意义的名称。

简化jQuery函数的参数列表

如果有一个函数有多个参数,但是并不是每一个参数都是必须的,可以把必须的参数放到前面,不必须的参数包装成一个object。

如:

function complex(param, options){
    var settings = $.extend(
        {
            option1 : defaultValue1,
            option2 : defaultValue2,
            option3 : defaultValue3
        }, options||{});
    // some other function body using settings
}

这里应该有一个说明,应该把options中的key值和value的默认值告知方法的调用者,以便让调用者设置相应的值。

函数是第一公民

虽然总是强调,但是真心不习惯。

但是把一个函数赋给一个变量,这个东西还是能够理解的。

var声明的最好是变量

如果在一个方法体中,有常量,那么这些常量尽量不要声明为变量(不适用var),而是作为当前方法的常量,如:

$.formatDate = function(date, parttern) {
    var result = [];
    // ...

    $.formatDate.partternParts = /^blablabla/;
    $.formatDate.monthNames = [‘January‘, ‘February‘ ...];
    $.formatDate.partternValue = {
        yyyy: function(date) {
            return date.getFullYear().toString();
        }
    }
}

正则表达式的匹配用parttern.exec(str),返回值为数组,且有一个lastIndex属性。。。。

str.slice(2)

arrary.join(" ")

包装器的方法

1 包装器的方法除非有特殊目的,否则要返回一个可以链化的对象;

2 他必须是$.fn的属性方法

3 this指代的是包装集,如果使用了this.each(fucntion(){ // this appears here is the current item})

jQueryInAction Reading Note 7.,布布扣,bubuko.com

时间: 2024-12-21 17:03:44

jQueryInAction Reading Note 7.的相关文章

jQueryInAction Reading Note 6.

这一章的前面一部分实在是无法理解,略过吧... $.noConflict() 无参数,无返回值,是用来把$符号交给其它的javascript库的. 但是并没有放弃使用jQuery的意思,jQuery仍然可以使用,并且可以把jQuery指派给另外一个别的名称,如$j,但是仍然会让人不爽. 但是如果在调用了$.noConflict()方法之后,还是想要使用$的话,可以使用一种方法,这种方法说白了就是设定一个形式参数$,而形式参数对应着的实体参数是jQuery,也就是说使用函数的方式. functio

jQueryInAction Reading Note 3.

属性和特性 操作元素属性 jQuery没有用于获取或者修改元素属性的命令.需要利用javascript,首先需要做的就是获得元素的引用. each(function) 对包装集中的各个元素,进行function操作,function有默认的参数为当前元素的位置,function具有当前对象this的引用. $("img").each(function(n){ this.alt = "this is " + n+1 + "th img, id is &quo

jQueryInAction Reading Note 5.

$(function(){ $('li:has(ul)') .click(function(event){ if (this == event.target){ if($(this).children().is(':hidden')){ $(this) .css('list-style-image', 'url(minus.gif)') .children().show(); } else { $(this) .css('list-style-image', 'url(plus.gif)') .

jQueryInAction Reading Note 4.

事件模型:javascript相关 事件模型的概念是浏览器的内容,却又与javascript相关 DOM第0级事件模型 在出现标准的事件模型之前,网景公司的网景航海家浏览器中引入了事件模型的概念. $("#someId")[0].onclick = function(event){//...} <img src="..." onclick="someFunction();" /> Event实例 javascript的每一个函数都有一

jQueryInAction Reading Note 2.

创建元素包装集 选择元素 1 CSS选择器 这个小猿比较熟悉,为了给一组相同的页面元素设置相同的样式,会用到CSS选择器: 2 子选择器 也就是万能的“>”号了吧.选择父元素的直接子元素,li > a,选择作为无序列表直接子元素的所有链接. 3 特性选择器 a[href^=http://]选择是以http://开头的所有的链接,a[href$=.pdf]选择指向一个pdf文件的所有链接. 如果我们并不关心其特性,可以省略=,如form[method],不管form是post还是get.据我所知

thinking in java ----reading note (1)

# thinking in java 4th# reading note# victor# 2016.02.10 chapter 1 对象入门 1.1 抽象的进步    (1) 所有东西都是对象.    (2) 程序是一大堆对象的组合,对象间通过消息联系.    (3) 通过封装现有对象,可制作出新型对象.    (4) 每个对象都有一种类型(某个类的实例).    (5) 同一类的所有对象都能接受相同的消息.    1.2 对象的接口 & 1.3 实现方法的隐藏     接口规定了可对一个特定

thinking in java -----reading note(2)

# thinking in java 4th# reading note# victor# 2016.02.16 chapter 2 一切都是对象 2.1 用句柄操纵对象    使用句柄作为标识符指向一个对象.但拥有句柄并不意味着有一个对象同它连接.    例如,创建一个String句柄: String s;    此时,这里创建的是句柄,并不是对象.如果向s发一条消息,就会获得一个错误.因此,较为安全的做法是:创建一个句柄时,无论如何都进行初始化. 2.2 创建对象    通常使用 new 关

thinking in java ----reading note (3)

# thinking in java 4th# reading note# victor# 2016.03.13 chapter 3 控制程序流程 3.1 java 运算符    几乎所有运算符都只能操作"基本值类型"."=","=="和"!=" 能操作所有对象,String类支持"+"和"+=". 3.1.1 优先级    运算符的优先级决定了存在多个运算符时一个表达式个部分的计算顺序

Programming In Scala Reading Note 3

Class and Object class TestClass { val some = 1 } 生成的class文件中会包含一个some()方法,并且这个方法是public的,也就是说类外可以通过类的对象来获取这个some的值 修改: class TestClass { private val some = 1 } 会生成一个private的some()方法,返回值也是some.但是现在类外是访问不到的 类的方法的参数默认是val类型的 副作用大部分用来修改一个属性的值或者开关一个I/O,只