`
和谐是美
  • 浏览: 49612 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

js 上下文

阅读更多

在JavaScript中,你的代码将总是有着某种形式的上下文(代码在其内部工作的 对象)。这也是其它面向对象语言所共有的功能,但它们都不如JavaScript处理得这样极端。上下文是通过变量this工作。变量this总是引用代 码当前所在的那个对象。记住全局对象实际上是window对象的属性。这意味着即使是在全局上下文里,this 变量仍然引用一个对象。上下文可以成为一个强大的工具,是面向对象代码不可或缺的一环。程序1展示了一些关于上下文的简单例子。

 

程序1. 在上下文中使用函数然后将其上下文切换到另一个变量的例子

 

代码
 1  var  obj  =  {
 2  yes:  function (){
 3  //  this == obj
 4  this .val  =   true ;
 5  },
 6  no:  function (){
 7  this .val  =   false ;
 8  }
 9  };
10  // 我们看到,obj对象没有"val"的属性
11  alert( obj.val  ==   null  );
12  // 我们运行yes函数,它将改变附着在obj 对象的val属性
13  obj.yes();
14  alert( obj.val  ==   true  );
15  // 然而,我们现在让window.no指向obj.no方法,并运行之
16  window.no  =  obj.no;
17  window.no();
18  // 这导致obj对象保持不变(上下文则切换到了window对象),
19  alert( obj.val  ==   true  );
20  // 而window的val属性被更新
21  alert( window.val  ==   false  );

 

你 可能已经注意到,在程序1中,当我们切换obj.no方法的上下文到变量window时,笨重的代码需要切换函数的上下文。幸运的 是,JavaScript 提供了两种方法使这一过程变得更加易于理解和实现。程序2展示了恰能些目的的两种不同方法,call和apply。 

 

程序2. 改变函数上下文的示例 

 

代码

 1  // 一个简单的设置其上下文的颜色风格的函数
 2  function  changeColor( color ) {
 3  this .style.color  =  color;
 4  }
 5  // 在window对象上调用这个函数将会出错,因为window没有style对象
 6  changeColor(  " white "  );
 7  // 得到一个id为"main"的对象
 8  var  main  =  document.getElementById( " main " );
 9  // 用call方法改变它的颜色为黑
10  // call方法将第一个参数设置为上下文,
11  // 并其它所有参数传递给函数
12  changeColor.call( main,  " black "  );
13  // 一个设置body元素的颜色的函数
14  function  setBodyColor() {
15  // apply方法设置上下文为body元素
16  // 第一个参数为设置的上下文,
17  // 第二个参数是一个被作为参数传递给函数的数组
18  //  of arguments that gets passed to the function
19  changeColor.apply( document.body, arguments );
20  }
21  // 设置body元素的颜色为黑
22  setBodyColor(  " black "  );
分享到:
评论

相关推荐

    js上下文理解

    ### JS上下文理解 #### 一、什么是JS执行上下文? 在JavaScript中,**执行上下文**(Execution Context,简称EC)是理解程序执行过程的关键概念之一。每当代码执行时,都会创建一个新的执行上下文。根据不同的场景...

    basicContext.js - 强大的纯Js上下文菜单插件.zip

    今天我们将深入探讨一个名为“basicContext.js”的纯JavaScript上下文菜单插件,它以其强大的功能和灵活性,成为开发者们喜爱的工具之一。 “basicContext.js”是一款轻量级的插件,主要特点在于其无需依赖任何外部...

    basicContext.js - 强大的纯Js上下文菜单插件

    总之,`basicContext.js` 是一个功能全面、易于定制的JavaScript上下文菜单解决方案,无论是在小型项目还是大型应用中,都能提供出色的服务。其灵活性、可扩展性和良好的文档支持,使得它成为开发者在构建网页交互...

    JS鼠标右键上下文菜单配置插件.zip

    首先,让我们深入了解一下JavaScript上下文菜单的基本概念。在HTML中,浏览器默认为每个元素提供了右键点击的上下文菜单,通常包含复制、粘贴等基本操作。然而,开发者可以通过JavaScript覆盖这个默认行为,创建...

    深入理解JavaScript执行上下文、函数堆栈、提升的概念.pdf

    JavaScript 执行上下文、函数堆栈、提升的概念是编程语言内部工作原理的重要组成部分。执行上下文可以理解为当前 JavaScript 代码被评估和执行时的一个环境,其中包含了变量、函数声明、作用域链以及 `this` 的值。...

    JavaScript上下文菜单控件

    JavaScript上下文菜单控件是一种在Web应用程序中实现的交互式功能,它允许用户在右键点击页面元素时显示自定义的菜单选项。这种技术增强了用户体验,因为它提供了比默认浏览器上下文菜单更具体、更相关的选择。 ...

    Contextual.js:Javascript上下文菜单库

    Javascript上下文菜单库-创建动态的右键单击或弹出菜单。 菜单 选项 isSticky 宽度 项目 菜单项 种类 子菜单 悬停菜单 分隔符 纽扣 自定义元素 多按钮(WIP) 选项 图标 cssIcon 标签 类型 onClick 捷径 子菜单 ...

    contextmenu:完美像素的OS风格javascript上下文菜单

    可以使用HTML上下文菜单表示法来指定标记,也可以使用contextmenu对象提供的简单Javascript API构建DOM节点,并添加一些JavaScript以确保浏览器的兼容性。 API范例 var menu = contextmenu([ { label: "First ...

    asynctx:在相关异步资源之间共享Node.js上下文

    `asynctx`库是为了解决在Node.js中处理异步任务时上下文共享的问题。本文将深入探讨`asynctx`库的工作原理、使用方法以及它如何帮助我们在相关异步资源之间共享Node.js上下文。 首先,让我们理解一下什么是上下文。...

    basicContext.js - 强大的纯Js上下文菜单插件特效代码

    总的来说,`basicContext.js` 是一个强大的JavaScript上下文菜单解决方案,它提供了丰富的功能和高度的可定制性,适合各种Web应用的需求。无论你是初学者还是经验丰富的开发者,都能通过这款插件快速创建出符合自己...

    执行上下文1

    执行上下文是JavaScript引擎在解析和运行代码时的关键概念,它是理解JavaScript运行机制的基础。执行上下文(Execution Context,简称EC)是ECMAScript标准中的一个抽象概念,用来区分可执行代码(Executable Code)...

    context-js:JavaScript 上下文菜单库

    Context.js 是一个用于 Web 的上下文菜单库,当然是用 JavaScript 编写的。 你可以试试这个。 安装 步骤1 将上下文文件夹复制到您的项目目录。 第2步 将 CSS 样式链接到您的 HTML 代码 < link rel =" ...

    定制编辑框的上下文菜单

    在编程和软件开发中,上下文菜单(Context Menu)是一种常用的人机交互元素,它根据用户的操作环境提供相关的操作选项。在编辑框中,上下文菜单通常包含与文本操作相关的命令,如复制、粘贴、剪切等。本文将深入探讨...

    Contextify:具有FontAwesome支持的轻量级香草JavaScript上下文菜单库

    具有FontAwesome支持的轻量级香草JavaScript上下文菜单库。 这个库是为在我的个人项目中使用而编写的,它是针对上下文菜单功能的AIO解决方案,我希望我只能分散在多个不同的上下文菜单库中。 这是很早的时候,我将...

Global site tag (gtag.js) - Google Analytics