博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[js高手之路] 跟GhostWu一起封装一个字符串工具库-架构篇(1)
阅读量:6265 次
发布时间:2019-06-22

本文共 1741 字,大约阅读时间需要 5 分钟。

所谓字符串工具库就是利用javascript面向对象的知识封装一个常用的字符串处理方法库,首先给这个库起个名字,好吧就叫ghostwu.js。

看下ghostwu.js的整体架构:

1 ; (function (window, undefined) { 2     function init(obj, s) { 3         if (s !== null && s !== undefined) { 4             if (typeof s === 'string') { 5                 obj.s = s; 6             } else { 7                 obj.s = s.toString(); 8             } 9         } else {10             obj.s = s;11         }12     }13 14     function G(s) {15         init(this, s);16     }17 18     function GhostWu(s) {19         return new G(s);20     }21 22     G.prototype = {23         constructor: G,24         capitalize: function () {25             return new this.constructor(this.s.slice(0, 1).toUpperCase() + this.s.substring(1).toLowerCase());26         }27     };28 29     window.G = GhostWu;30 })(window, undefined);

1,最外层采用jquery的

2,紧接着在第29行暴露一个接口函数GhostWu

3,Ghostwu这个函数返回一个new G()对象, 目的是把 new G()这个对象 传递给init中的this, GhostWu中的参数s 自然就是 等待被处理的字符串

4,init函数的作用,就是给obj对象,也就是new G()对象添加一个属性s用来存储字符串

5,init函数中对s进行了类型和值是否为空的判断

  • 如果为空,就把s直接赋值给obj( 第 10 行 )
  • 如果不为空,分两种情况处理, 如果是字符串直接赋值给obj( 第5行 ). 如果是数组,把数组用toString函数转成字符串赋值给obj( 第7行 )

 6,所以整体运行流程

  先执行第29行,在全局对象window上挂载一个公共属性G, 而G就是我们的GhostWu函数, 假设我们在外面调用G( 'ghostwu' ),程序接着就会执行Ghostwu这个函数

  把字符串 'ghostwu' 当做参数传递给new G, 那么new G中的this指向的就是new G(), s 就是 'ghostwu' ,然后通过init传参,经过第三行的条件判断和第四行的条件判断

  为new G()对象上添加了一个属性s, 值为'ghostwu' , 结果类似:   { s : 'ghostwu' }

7,第22行,之后的所有工具函数都是扩展在G的原型对象上,即G.prototype

8,第23行,设定constructor构造属性的值为G,因为原型对象采用的是字面量方式,重写了默认的G函数原型对象, constructor指向为Object, 所以在这里我们要用

constructor强行让构造属性指向构造函数G

9,第24行,我们为ghostwu.js这个工具库扩展了第一个方法: capitalize,作用是把字符串首字母变成大写,后面的字母变成小写

console.log( G( 'ghostwu' ).capitalize().s ); //Ghostwu
console.log( G( ['ghostwu'] ).capitalize().s ); //Ghostwu

 

转载地址:http://kcdpa.baihongyu.com/

你可能感兴趣的文章
用JS实现任意导航栏的调用
查看>>
【GDOI2018】所有题目和解题报告
查看>>
【BZOJ】3302: [Shoi2005]树的双中心 && 2103: Fire 消防站 && 2447: 消防站
查看>>
存储过程与触发器面试
查看>>
CSS系列:在HTML中引入CSS的方法
查看>>
Orcale约束-------檢查約束
查看>>
VS2013 配置CUDNN V4 DEMO
查看>>
Codeforces Round #207 (Div. 2)C. Knight Tournament
查看>>
JS(JavaScript)的进一步了解5(更新中···)
查看>>
python3基础学习笔记
查看>>
STL模板整理 pair
查看>>
【转】jmeter学习笔记——一个简单的性能测试
查看>>
企业级镜像管理系统Harbor
查看>>
A Plain English Guide to JavaScript Prototypes
查看>>
学习总结汇总
查看>>
Beta阶段测试报告
查看>>
JQ 练习题
查看>>
AndroidStudio、gradle、buildToolsVersion关系
查看>>
WPF入门教程系列八——布局之Grid与UniformGrid(三)
查看>>
递归调用顺序问题
查看>>