Web组件开发基础

在具体页面开发的过程中,难免遇到各种各样的组件需求,除了已经提供的input,select等等,还有未提供的例如日历组件(H5已经简单集成),富文本编辑器、 弹出框等。最简单的就是要解决复用的问题。
(一)最简单的组件定义
随意一个tabview组件为例,首先要包含css样式和js行为。


这是css文件

这是js文件,图片中缺了一句,需要把TabView挂载到window全局变量中来使用。window.TabView=TabView;

这是在页面中引用文件并实例化组件

如上所示,一个组件对应一套 css、js文件,并实例化。这种方式显然是不合理的,主要问题有:
··1.css文件中可能重复定义类名(使用命名空间的方式解决)等变量。
··2.js文件中的变量也可能重复(使用上图的匿名函数解决)。
··3.每个文件都向window全局函数进行挂载,当组件数量较多时,window变量也越来越大。
··4.页面引用的文件也会越来越多。
··5.组件和组件之间的依赖关系也没有解决。

为了解决这些问题,使用require.js进行模块化开发(官网: http://requirejs.org/ ),一个js文件可看作一个模块。

require.js的两个核心函数:
1.define(['mod1','mod2',...] , function(m1,m2,...){ return {暴露出来的变量}; }):定义一个模块。这个函数接收两个参数,第一个函数(可选)是一个数组,['mod1','mod2',...] 即定义当前模块需要引用的别的模块名,如果没有依赖别的模块(即别的js文件),则不写。第二个参数是一个函数,里面写是当前模块的内容。需要注意的是,第一个参数引用了几个模块,第二个参数function中的参数就有多少个。mod1,mod2的数量对应m1,m2的数量。在这个函数中,通过return,将外部可访问的变量暴露出来。

2.require(['mod1','mod2',...] , function(m1,m2,...){ }):引用模块。整个页面从require函数开始执行。这个函数依然接收两个参数,第一个参数是需要引用的模块数量,第二个参数是一个函数,需要执行的代码
当然require.js还有各种api,但是在实际开发的过程中,用到的比较少,所以先不详细介绍了。

在html文件中引用方式:在body底部,把require.js这个库引用进来。data-main这个自定义属性引用的就是自己在js文件夹中定义的入口文件main.js。require.js会自动的访问data-main中保存的文件,

<script type="text/javascript" src="require.js" data-main="js/main"></script>

代码:先定义两个模块
1.animate.js:

define(function(){
function Animate(){
this.name = "Animate";
}
return {
Animate : Animate
}
});

2.treeview.js

define(function(){
function TreeView(){
this.name = 'TreeView';
};

return {
    TreeView : TreeView
};

});

3.定义第三个模块,tabview.js,需要引用animate模块
define(['animate'],function(a){
function TabView(){
this.name = "TabView";
this.animate = new a.Animate();
};

return {
    TabView : TabView
};

});

4.定义程序主入口 main.js ,需要引用 treeview 和 tabview 两个模块,弹出三个模块的名称。
require(['tabview','treeview'],function(tab,tree){
var tabView = new tab.TabView(),
treeView = new tree.TreeView();

alert(tabView.name);
alert(treeView.name);
alert(tabView.animate.name);

});

5.在html中引用下载好的require.js
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>require.js</title>
</head>
<body>

<script type="text/javascript" data-main="js/main" src="../require.js"></script>  

</body>
</html>

在浏览器中执行的结果是一次有三个alert弹窗,弹出了三个名字。

还有一个例子,在github上,是一个自定义的弹出框组件:
https://github.com/WebPuY/modelWindow.git

                                                                                                                              感谢真阿当老师的教程
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容