js 编写规范

    在一个项目中大量使用js,工程项目与网站开发有一些不一样,在我接触的工程项目中普遍使用js 不够多,大部分客户端可做事,交给了服务端,而且在使用js时不够规范,很容易造成代码难以阅读、内存泄漏问题,不注意js 输写方式。而在网站开发中(尤其一些大网站,js输出的非常漂亮、完美无论使用jquery,还是prototype 框架,还是不用框架,都有自己良好一套东东可用)

   js输写最好还是可以面向对象方式 用类方向进行包装 js输写两种方式 闭包 原型 

   闭包:(借用的一个例子)

代码
1   // 定义构造函数
2 function Person(name)
3 {
4 this .name = name; // 在构造函数中定义成员
5 };
6
7 // 方法定义到构造函数的prototype上
8 Person.prototype.SayHello = function ()
9 {
10 alert( " Hello, I'm " + this .name);
11 };
12
13 // 子类构造函数
14 function Employee(name, salary)
15 {
16 Person.call( this , name); // 调用上层构造函数
17 this .salary = salary; // 扩展的成员
18 };
19
20 // 子类构造函数首先需要用上层构造函数来建立prototype对象,实现继承的概念
21 Employee.prototype = new Person() // 只需要其prototype的方法,此对象的成员没有任何意义!
22
23 // 子类方法也定义到构造函数之上
24 Employee.prototype.ShowMeTheMoney = function ()
25 {
26 alert( this .name + " $ " + this .salary);
27 };
28
29 var BillGates = new Person( " Bill Gates " );
30 BillGates.SayHello();
31
32 var SteveJobs = new Employee( " Steve Jobs " , 1234 );
33 SteveJobs.SayHello();
34

   原型:(借用的一个例子)

代码
1 function Person(firstName, lastName, age)
2 {
3 // 私有变量:
4   var _firstName = firstName;
5 var _lastName = lastName;
6
7 // 公共变量:
8   this .age = age;
9
10 // 方法:
11   this .getName = function ()
12 {
13 return (firstName + " " + lastName);
14 };
15 this .SayHello = function ()
16 {
17 alert( " Hello, I'm " + firstName + " " + lastName);
18 };
19 };
20
21 var BillGates = new Person( " Bill " , " Gates " , 53 );
22  

 

这两种方法各有优缺点,第一种看起来更像一个类 每个对象设置一份方法有很大浪费,而且资源回收不利,第二种方法,看起来不是很漂亮,可性能很好(不过如果你使用prototype框架,就可以完美解决结构与性能问题了。)

 

实际在使用jquery 还是prototype问题上,我的一点点体会是 jquery使用闭包方式,而prototype当然原型,jquery更加适合对单个对象操作,而prototype更适合做一些客户端控件。实际我更喜欢在项目中使用jquery 而网站上更关注prototype

转载于:https://www.cnblogs.com/shouhongxiao/archive/2010/03/03/1676988.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值