JavaScript中function的详细理解(附代码)

互联网 19-4-11
本篇文章给大家带来的内容是关于JavaScript中function的详细理解(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

JavaScript 中的 function 有多重意义。它可能是一个构造器(constructor),承担起对象模板的作用; 可能是对象的方法(method),负责向对象发送消息。还可能是函数,没错是函数,和对象没有任何关系独立存在的可以被调用的函数。

由于语言设计者的妥协,在 JavaScript 加入了一些 class 相关的特性,以使 JavaScript 看起来确实象 Java,可以 “面向对象”。虽然 JavaScript 添加了 new 和 this, 但却没有 class (ES已加)。最后 function 临时担负起 class 的任务。

语义1:作为构造器的 function

/** @class Tab @param nav {string} 页签标题的class @param content {string} 页面内容的class **/ function Tab(nav, content) {  this.nav = nav;  this.content = content; } Tab.prototype.getNav = function() {  return this.nav; }; Tab.prototype.setNav = function(nav) {  this.nav = nav; }; Tab.prototype.add = function() { }; // 创建对象 var tab = new Tab('tab-nav', 'tab-content');

这里定义了一个类 Tab,创建了一个对象 tab。以上使用了 function ,this, new。this, new 是常见的面向对象语言中的关键字, 这里的 function 则担负传统面向对象语言中的 class 作用。当然这时候标识符的命名一般遵循 “首字母大写” 规则。

语义2:作为对象方法的 function

由于 JavaScript 中无需类也可以直接创建对象,因此有两种方式给对象添加方法。第一种先定义类,方法挂在原型上,如上例的 Tab,原型上有 getNav、setNav 和 add 方法。以下还有一种,直接在 function 内的 this 上添加方法。

function Tab(nav, content) {  this.nav = nav  this.content = content  this.getNav = function() { // ... }  this.setNav = function() { // ... }  this.add = function() { // ... } }

这里 Tab 是语义, this.getNav/this.setNav/this.add 是语义,作为对象的方法。 另外,可以直接定义对象及其方法

var tab = {  nav: '',  content: '',  getNav: function() { // ... },  setNav: function() { // ... },  add: function() { // ... } }

tab.getNav/tab.setNav/tab.add 是语义,作为对象 tab 的方法。语义3:作为独立的函数

/* 判断对象是否是一个空对象 @param obj {Object} @return {boolean} */ function isEmpty(obj) {  for (var a in obj) { return false }  return true } // 定义一个模块 ~function() {  // 辅助函数  function now() { return (new Date).getTime() }  // 模块逻辑... }(); // 采用CommonJS规范的方式定义一个模块 define(require, exports, moduel) {  // 辅助函数  function now() { return (new Date).getTime() }  // 模块逻辑... })
// 全局命名空间 var RUI = {} // ajax.js ~function(R) {  // 辅助函数...  ajax = { request: function() {   // ... } getJSON: function() {   // ... } ... }  // 暴露出模块给 R  R.ajax = ajax }(RUI); // event.js ~function(R) {  // 辅助函数...  // 事件模块定义...  // 暴露出模块给 R  R.event = event }(RUI); // dom.js ~function(R) {  // 辅助函数...  // DON模块定义...  // 暴露出模块给 R  R.dom = dom }(RUI);

这里的匿名函数执行后把API对象暴露给了RUI,无论匿名函数内干了多少活,对应匿名函数外是看不到的,也是没有必要去理会的。最终关心的是公开的 API 方法,只要了解这些方法的参数及意义就可以马上使用它了。

语义5:匿名函数处理某些特殊效果如处理一些数据又不想暴露过多的变量

// 判断IE版本的hack方式 var IEVersion = function() {  var undef, v =   var p = document.createElement('p')  var all = p.getElementsByTagName('i')  while ( p.innerHTML = '<!--[if gt IE ' + (++v) + ']><i></i><![endif]-->', all[] );  return v > ? v : undef }();

最终只要一个结果 IEVersion,匿名函数内部用到了一些局部变量全部可以隔离开。这种方式对于一些临时性的数据加工非常有效,紧凑。【相关推荐:JavaScript视频教程】

以上就是JavaScript中function的详细理解(附代码)的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: JavaScript
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:Cookie和Session的区别总结

相关资讯