JS常见的API扩展形式有哪些

本文小编为大家详细介绍“JS常见的API扩展形式有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“JS常见的API扩展形式有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

公司主营业务:成都网站设计、成都网站制作、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联建站是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联建站推出卫东免费做网站回馈大家。

比如我现在有一个需求,给定一个字符串,给方法传递一个参数为数字类型来确定当前字符串重复次数,例如:

'abc'.repeatStringNumTimes(3)?//?abcabcabc

如果按照一般的思维就是我们把这个方法绑定到String的原型上,如下代码:

String.prototype.repeatStringNumTimes?=?String.prototype.repeatStringNumTimes?||?function(times)?{var?str?=?'';for(var?i?=?0;?i?

str?+=?this;

}return?str;

}

jQuery插件开发方式主要有三种:

通过$.extend()来扩展jQuery

通过$.fn 向jQuery添加新的方法

通过$.widget()应用jQuery UI的部件工厂方式创建

通常我们使用第二种方法来进行简单插件开发,说简单是相对于第三种方式。第三种方式是用来开发更高级jQuery部件的,该模式开发出来的部件带有很多jQuery内建的特性,比如插件的状态信息自动保存,各种关于插件的常用方法等,非常贴心,这里不细说。

而第一种方式又太简单,仅仅是在jQuery命名空间或者理解成jQuery身上添加了一个静态方法而以。所以我们调用通过。extend()添加的函数时直接通过。extend()添加的函数时直接通过符号调用($.myfunction())而不需要选中DOM元素($('#example')。myfunction())。请看下面的例子。

$.extend({

sayHello:?function(name)?{

console.log('Hello,'?+?(name?name?:?'Dude')?+?'!');

}

})

$.sayHello();?//调用$.sayHello('Wayou');?//带参调用

看一个jquery封装的面向对象的插件开发代码:

//定义Beautifier的构造函数var?Beautifier?=?function(ele,?opt)?{this.$element?=?ele,this.defaults?=?{'color':?'red','fontSize':?'12px','textDecoration':'none'

},this.options?=?$.extend({},?this.defaults,?opt)

}//定义Beautifier的方法Beautifier.prototype?=?{

beautify:?function()?{return?this.$element.css({'color':?this.options.color,'fontSize':?this.options.fontSize,'textDecoration':?this.options.textDecoration

});

}

}//在插件中使用Beautifier对象$.fn.myPlugin?=?function(options)?{//创建Beautifier的实体

var?beautifier?=?new?Beautifier(this,?options);//调用其方法

return?beautifier.beautify();

}

调用方式:

$(function()?{

$('a')。myPlugin({'color':?'#2C9929','fontSize':?'20px'

});

})

读到这里,这篇“JS常见的API扩展形式有哪些”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注创新互联行业资讯频道。


分享文章:JS常见的API扩展形式有哪些
本文URL:http://csdahua.cn/article/pgeieg.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流