之前因项目需要也编写过一些简单的JS组件,大多是基于JQuery库的,一直也没有过总结,导致再次写到的时候还去Google, 近日看到一个文章总结的挺好,拿过整理一下做个备忘。

此次同样是基于jquery库来开发,根据一个例子来循序渐进地说明。

了解AngularJs的同学知道,其最具魅力的特点莫过于双向绑定,那么我们今天也来实现一个双向绑定的组件,在一个text文本框后面显示输入的文本内容。

 <大概长这个模样>

1. 常规实现思路   

 <input id="txt-con" type="text" />
<script>
$(function(){
var textInput = $("#txt-con");
textInput.bind('keyup', function(){
if (textInput.val()) {
appendText(this, textInput.val());
}
}); var appendText = function(target, content) {
var id = target.id + "-present";
if ($("#" + id).length > 0) {
$("#" + id).text(content);
} else {
$(target).after("<h2 id='"+id+"'>"+content+"</h2>");
}
}
})
</script>

 以上代码可以妥妥的跑,达到预期的目的。但是细心的你会发现,我们的完全没有考虑作用域的问题,appendText 方法被暴露在全局作用域里面,如果这一个页面中有几十上百个这样的全局变量,那维护起来会疯掉。

2. “隔离”作用域

我们现在对上面的代码进行一些修改,引入一个单独的命名空间。

 var TextPresenter = {
init: function(id){
var textInput = $(id);
var self = this;
textInput.bind("keyup", function() {
if(textInput.val()) {
self.appendText(this, textInput.val()); //注意这里的self变量,是将TextPresenter对象的引用赋给了self
}
})
}, appendText: function(target, content){
var id = target.id + "-present";
if ($("#" + id).length > 0) {
$("#" + id).text(content);
} else {
$(target).after("<h2 id='"+id+"'>"+content+"</h2>");
}
},
} //以上部分你可以写进一个单独的js文件了,如jquery.textpresenter.js, 别忘了在document ready后初始化

  $(function(){
    TextPresenter.init("#txt-con");

  })

以上部分有点组件的雏形了不是,很多时候就这样被拿来用了,如果你再细细一想,好像有哪里不对,因为 TextPresenter 里面的所有成员变量都可以在外部被访问,而没有一点私有化的概念在里面。所以,说是隔离其实并没有真正隔离,只是看起来像是隔离了。

3. 真正隔离作用域

说到作用域的隔离,我们不得不引入闭包的概念了。曾经看了多少遍闭包的概念,然而实际用到的机会少之又少。借此也来实践一下闭包的基础知识。

 var TextPresenter = (function(){
var appendText = function(target, content) { //此方法成了私有化方法,外部不可直接访问
var id = target.id + "-present";
if ($("#" + id).length > 0) {
$("#" + id).text(content);
} else {
$(target).after("<h2 id='"+id+"'>"+content+"</h2>");
}
}; var TextPresenterFun = function() {
this.init = function(id) {
var textInput = $(id);
textInput.bind("keyup", function() {
if(textInput.val()) {
appendText(this, textInput.val());
}
})
}
}; return TextPresenterFun; //返回构造函数,在调用此组件时需要实例化,然后调用init方法 })();   new TextPresenter().init("#txt-con"); //调用的过程

这种方式可以创建必要的私有方法,对外开放的只有init方法,具体的内部逻辑并不对外开放,满足我所要求的隔离作用域的需求。事实上,大多数的jQuery组件都是这么实现的。

先写这么多吧,都是些基础,作为一个入门,要走的路还长着啊。

浅析 JavaScript 组件编写的更多相关文章

  1. JavaScript 组件编写

    说明 这是一个联系人名过滤组件,还提供可选的"大小写是否敏感"选项,默认大小写不敏感. 一.HTML 结构 <ul class="contacts"> ...

  2. JavaScript手工编写滚动条组件

    0 前言 上周的一个练习,由于没来得及编写笔记,这里补充一下~ 虽然CSS3中提供了overflow:scroll; 来实现滚动条,但是这里可以使用原生JS来编写一个,以达到练习组件编写的效果. 练习 ...

  3. 试试用有限状态机的思路来定义javascript组件

    本文是一篇学习性的文章,学习利用有限状态机的思想来定义javascript组件的方法,欢迎阅读,后续计划会写几篇专门介绍自己利用有限状态机帮助自己编写组件的博客,证明这种思路对于编程实现的价值,目前正 ...

  4. Winjs – 微软开源技术发布的 JavaScript 组件集

    Winjs 是由微软开源技术的开发者推出的一组 JavaScript 组件,包括 ListView.ListView.Tooltip.DatePicker.Ratings 等等,帮助 Web 开发人员 ...

  5. javascript组件化(转)

    javascript组件化(转) By purplebamboo 3月 16 2015 更新日期:3月 23 2015 文章目录 1. 最简陋的写法 2. 作用域隔离 3. 面向对象 4. 抽象出ba ...

  6. javascript组件开发之基类继承实现

    上一篇文章大概的介绍了一下关于javascript组件的开发方式,这篇文章主要详细记一下基类的编写,这个基类主要是实现继承的功能 为什么要封装基类? 由于这次重构项目需要对各种组件进行封装,并且这些组 ...

  7. (转)javascript组件开发方式

    作为一名前端工程师,写组件的能力至关重要.虽然javascript经常被人嘲笑是个小玩具,但是在一代代大牛的前仆后继的努力下,渐渐的也摸索了一套组件的编写方式. 下面我们来谈谈,在现有的知识体系下,如 ...

  8. [转] javascript组件开发方式

    作为一名前端工程师,写组件的能力至关重要.虽然JavaScript经常被人嘲笑是个小玩具,但是在一代代大牛的前仆后继的努力下,渐渐的也摸索了一套组件的编写方式. 下面我们来谈谈,在现有的知识体系下,如 ...

  9. javascript 组件化(转载)

    这边只是很简陋的实现了类的继承机制.如果对类的实现有兴趣可以参考我另一篇文章javascript oo实现 我们看下使用方法: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...

随机推荐

  1. 一个Hadoop难以查找的错误

    This script is Deprecated. Instead use start-dfs.sh and start-yarn.sh Starting namenodes on [Master1 ...

  2. 类和对象:一些相关的BIF - 零基础入门学习Python040

    类和对象:一些相关的BIF 让编程改变世界 Change the world by program 一些类和对象相关的 BIF 今天我们来谈谈跟类和对象相关的一些BIF(内置函数): issubcla ...

  3. 未能在全局命名空间中找到类型或命名空间名称“Wuqi”

    下载了AspNetPager控件用以进行分页操作,在项目中放入控件后,运行报错:未能在全局命名空间中找到类型或命名空间名称“Wuqi” . 解决办法:在项目下拉框“引用“中添加AspNetPager引 ...

  4. iOS开发 masonry 设置tableHeadView

    最近做公司项目,使用到到tableHeadView,一直习惯用masonry来设置约束,但是设置tableHeadView没有那么的简单.先看下效果图: 视图层次结构是这样的: 基础的创建工程项目之类 ...

  5. Oracle set autotrace 时提示:Cannot find the Session Identifier. Check PLUSTRACE role is enabled

    SQL> set autotrace Usage: SET AUTOT[RACE] {OFF | ON | TRACE[ONLY]} [EXP[LAIN]] [STAT[ISTICS]] SQL ...

  6. NGINX和PHP之间的环境变量传递

    昨天遇到的,想将IP访问转换成域名访问.则NGINX需要将相关的变量转换后传递给PHP. 网上有一系统的方法: 前面讲过该不该把信息写在服务器配置文件里?.通过php扩展hidef来define常量, ...

  7. LeetCode_Maximal Rectangle

    Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and ...

  8. Unity 3D中的界面快捷键

    Ctrl+1 切换到Scene视图Ctrl+2 切换到Game视图Ctrl+3 切换到Inspector视图Ctrl+4 切换到Hierarchy视图Ctrl+5 切换到Project视图Ctrl+6 ...

  9. WPF中使用文件浏览对话框的几种方式

    原文:WPF中使用文件浏览对话框的几种方式 WPF本身并没有为我们提供文件浏览的控件, 也不能直接使用Forms中的控件,而文件浏览对话框又是我们最常用的控件之一. 下面是我实现的方式 方式1: 使用 ...

  10. SmartBusinessDevFramework架构设计-2:结构图示

    架构设计一览图 下图表示了本架构的设计草稿. 接下来  ,我们将逐步细述,各个模块之间的松散耦合关系. 核心的实现原理.敬请关注.