码迷,mamicode.com
首页 > Web开发 > 详细

jQuery的Internal DSL

时间:2014-08-04 17:27:40      阅读:213      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   io   问题   cti   代码   div   

JQuery的核心理念是write less,do more(写的更少,做的更多),那么链式方法的设计与这个核心理念不谋而合。那么从深层次考虑这种设计其实就是一种Internal DSL。

DSL是指Domain Specific Language,也就是用于描述和解决特定领域问题的语言

我们贴一段代码:

$(‘input[type="button"]‘)
    .eq(0).click(function() { 
        alert(‘点击我!‘);
}).end().eq(1)
.click(function() { 
    $(‘input[type="button"]:eq(0)‘).trigger(‘click‘);
}).end().eq(2)
.toggle(function() {
    $(‘.aa‘).hide(‘slow‘);
}, function() {
    $(‘.aa‘).show(‘slow‘);
});

看这个代码的结构,我们或多或少都能猜到其含义:

l 找出type类型为button的input元素

l 找到第一个按钮,并绑定click事件处理函数

l 返回所有按钮,再找到第二个

l 为第二个按钮绑定click事件处理函数

l 为第三个按钮绑定toggle事件处理函数

那么可见jQuery的Internal DSL形式带来的好处——编写代码时,让代码更贴近作者的思维模式;阅读代码时,让读者更容易理解代码的含义

应用DSL可以有效的提高系统的可维护性(缩小了实现模型和领域模型的距离,提高了实现的可读性)和灵活性,并且提供开发的效率

jQuery的Internal DSL,布布扣,bubuko.com

jQuery的Internal DSL

标签:style   blog   color   io   问题   cti   代码   div   

原文地址:http://www.cnblogs.com/aaronjs/p/3890439.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!