当前位置: 首页 > news >正文

济南专业做企业网站漂亮的博客网站模板

济南专业做企业网站,漂亮的博客网站模板,未来最吃香的十大行业,怎样建设网站啊随着网站逐渐变成互联网应用程序#xff0c;嵌入网页的Javascript代码越来越庞大#xff0c;越来越复杂。 网页越来越像桌面程序#xff0c;需要一个团队分工协作、进度管理、单元测试等等......开发者不得不使用软件工程的方法#xff0c;管理网页的业务逻辑。…  随着网站逐渐变成互联网应用程序嵌入网页的Javascript代码越来越庞大越来越复杂。 网页越来越像桌面程序需要一个团队分工协作、进度管理、单元测试等等......开发者不得不使用软件工程的方法管理网页的业务逻辑。 Javascript模块化编程已经成为一个迫切的需求。理想情况下开发者只需要实现核心的业务逻辑其他都可以加载别人已经写好的模块。 但是Javascript不是一种模块化编程语言它不支持类class更遑论模块module了。正在制定中的ECMAScript标准第六版将正式支持类和模块但还需要很长时间才能投入实用。 Javascript社区做了很多努力在现有的运行环境中实现模块的效果。本文总结了当前Javascript模块化编程的最佳实践说明如何投入实用。虽然这不是初级教程但是只要稍稍了解Javascript的基本语法就能看懂。 一、原始写法 模块就是实现特定功能的一组方法。 只要把不同的函数以及记录状态的变量简单地放在一起就算是一个模块。   function m1(){     //...   }   function m2(){     //...   } 上面的函数m1()和m2()组成一个模块。使用的时候直接调用就行了。 这种做法的缺点很明显污染了全局变量无法保证不与其他模块发生变量名冲突而且模块成员之间看不出直接关系。 二、对象写法 为了解决上面的缺点可以把模块写成一个对象所有的模块成员都放到这个对象里面。   var module1 new Object({     _count : 0,     m1 : function (){       //...     },     m2 : function (){       //...     }   }); 上面的函数m1()和m2(都封装在module1对象里。使用的时候就是调用这个对象的属性。   module1.m1(); 但是这样的写法会暴露所有模块成员内部状态可以被外部改写。比如外部代码可以直接改变内部计数器的值。   module1._count 5; 三、立即执行函数写法 使用立即执行函数Immediately-Invoked Function ExpressionIIFE可以达到不暴露私有成员的目的。   var module1 (function(){     var _count 0;     var m1 function(){       //...     };     var m2 function(){       //...     };     return {       m1 : m1,       m2 : m2     };   })(); 使用上面的写法外部代码无法读取内部的_count变量。   console.info(module1._count); //undefined module1就是Javascript模块的基本写法。下面再对这种写法进行加工。 四、放大模式 如果一个模块很大必须分成几个部分或者一个模块需要继承另一个模块这时就有必要采用放大模式augmentation。   var module1 (function (mod){     mod.m3 function () {       //...     };     return mod;   })(module1); 上面的代码为module1模块添加了一个新方法m3()然后返回新的module1模块。 五、宽放大模式Loose augmentation 在浏览器环境中模块的各个部分通常都是从网上获取的有时无法知道哪个部分会先加载。如果采用上一节的写法第一个执行的部分有可能加载一个不存在空对象这时就要采用宽放大模式。   var module1 ( function (mod){     //...     return mod;   })(window.module1 || {}); 与放大模式相比宽放大模式就是立即执行函数的参数可以是空对象。 六、输入全局变量 独立性是模块的重要特点模块内部最好不与程序的其他部分直接交互。 为了在模块内部调用全局变量必须显式地将其他变量输入模块。   var module1 (function ($, YAHOO) {     //...   })(jQuery, YAHOO); 上面的module1模块需要使用jQuery库和YUI库就把这两个库其实是两个模块当作参数输入module1。这样做除了保证模块的独立性还使得模块之间的依赖关系变得明显。这方面更多的讨论参见Ben Cherry的著名文章《JavaScript Module Pattern: In-Depth》。 七、模块的规范 先想一想为什么模块很重要 因为有了模块我们就可以更方便地使用别人的代码想要什么功能就加载什么模块。 但是这样做有一个前提那就是大家必须以同样的方式编写模块否则你有你的写法我有我的写法岂不是乱了套考虑到Javascript模块现在还没有官方规范这一点就更重要了。 目前通行的Javascript模块规范共有两种CommonJS和AMD。我主要介绍AMD但是要先从CommonJS讲起。 八、CommonJS 2009年美国程序员Ryan Dahl创造了node.js项目将javascript语言用于服务器端编程。 这标志Javascript模块化编程正式诞生。因为老实说在浏览器环境下没有模块也不是特别大的问题毕竟网页程序的复杂性有限但是在服务器端一定要有模块与操作系统和其他应用程序互动否则根本没法编程。 node.js的模块系统就是参照CommonJS规范实现的。在CommonJS中有一个全局性方法require()用于加载模块。假定有一个数学模块math.js就可以像下面这样加载。   var math require(math); 然后就可以调用模块提供的方法   var math require(math);   math.add(2,3); // 5 因为这个系列主要针对浏览器编程不涉及node.js所以对CommonJS就不多做介绍了。我们在这里只要知道require()用于加载模块就行了。 九、浏览器环境 有了服务器端模块以后很自然地大家就想要客户端模块。而且最好两者能够兼容一个模块不用修改在服务器和浏览器都可以运行。 但是由于一个重大的局限使得CommonJS规范不适用于浏览器环境。还是上一节的代码如果在浏览器中运行会有一个很大的问题你能看出来吗   var math require(math);   math.add(2, 3); 第二行math.add(2, 3)在第一行require(math)之后运行因此必须等math.js加载完成。也就是说如果加载时间很长整个应用就会停在那里等。 这对服务器端不是一个问题因为所有的模块都存放在本地硬盘可以同步加载完成等待时间就是硬盘的读取时间。但是对于浏览器这却是一个大问题因为模块都放在服务器端等待时间取决于网速的快慢可能要等很长时间浏览器处于假死状态。 因此浏览器端的模块不能采用同步加载synchronous只能采用异步加载asynchronous。这就是AMD规范诞生的背景。 十、AMD AMD是Asynchronous Module Definition的缩写意思就是异步模块定义。它采用异步方式加载模块模块的加载不影响它后面语句的运行。所有依赖这个模块的语句都定义在一个回调函数中等到加载完成之后这个回调函数才会运行。 AMD也采用require()语句加载模块但是不同于CommonJS它要求两个参数   require([module], callback); 第一个参数[module]是一个数组里面的成员就是要加载的模块第二个参数callback则是加载成功之后的回调函数。如果将前面的代码改写成AMD形式就是下面这样   require([math], function (math) {     math.add(2, 3);   }); math.add()与math模块加载不是同步的浏览器不会发生假死。所以很显然AMD比较适合浏览器环境。 目前主要有两个Javascript库实现了AMD规范require.js和curl.js。 转自 http://www.ruanyifeng.com/blog/2012/10/javascript_module.html http://www.ruanyifeng.com/blog/2012/10/asynchronous_module_definition.html
http://www.zqtcl.cn/news/251935/

相关文章:

  • 网站建设合同要存档几年7星彩网站开发
  • 网站建设好后 如何验收什么网站可以做护考题
  • 网站安全怎么做wordpress代币插件
  • 吉林网站建设电话龙华网站建设专业定制企业
  • 个人导航网站怎么备案js调用wordpress文章列表
  • 网站微信推广方案衡水外贸网站建设
  • 怎么打造自己的网站如何做自已网站
  • 美容美发网站模板wordpress适合优化吗
  • 网站开发的著作权和版权沧州市做网站价格
  • 优客逸家网站源码酒吧装修
  • 深圳网站制作的公司怎么样开工作室做网站怎样找资源
  • 大连城乡建设局网站seo编辑招聘
  • 网站建设意见怎么在中国移动做网站备案
  • 做内贸哪个网站找客户网络外包
  • 古玩网站建设意义钟山县住房和城乡建设局网站
  • 网站开发微信公众号自定义菜单规则网站建设
  • 营销网站建设工作教育培训wordpress主题
  • 温州地区做网站公司如何注册新公司
  • 做的网站怎样评估价值全国信息公示系统官网
  • 外国网站签到做任务每月挣钱1g内存vps 开电影网站
  • 营销型网站案例易网拓互联购物
  • 河南企业网站制作微信小程序如何做
  • 金坛住房和城乡建设局网站wordpress 需要授权吗
  • 个人理财的网站开发天津 公司网站建设
  • 做电脑游戏破解的网站大宗交易平台软件
  • 男女做暖暖视频免费网站网络营销策划案ppt
  • 普通网站 多大空间网站开发报告参考文献
  • 来宾住房和城乡建设网站pc网站建设哪
  • WordPress一键开启全站SSL东莞企业网站建设公司
  • 青海省公路建设管理局官方网站wordpress 加入地图