`
littie1987
  • 浏览: 133376 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Javascript上下文

阅读更多

    Context:(JS上下文)

   

var obj = {
       yes:function(){
           this.val=true;
       },
       no:function(){
           this.val=false;
       }
};
alert(obj.va);
obj.yes();
alert(obj.val);     

   上述代码中第一处打印是undefined,第二处打印的是true。说明此时val的上下文变了。

    下面更改代码:

var obj = {
       yes:function(){
           this.val=true;
       },
       no:function(){
           this.val=false;
       }
};
obj.yes();
window.no = obj.no;
window.no();
alert(obj.val);  

这段代码打印结果还是true,虽然调用了window.no()但是此时val的context已经上升到window,不会影响到obj。

 

使用Call和Apply可以控制context。

看代码:

var obj = {
       yes:function(){
           this.val=true;
       },
       no:function(){
           this.val=false;
       }
};
function Car(){
   //
}
var c = new Car();
obj.yes.call(c);
alert(c.val);

此时打印结果是true,Car对象奇迹般的拥有了val属性。且此时val的作用context只是car对象,即c;如果试着打印alert(obj.val)。得到的结果会是undefined。这样就控制了context的变化。Apply的用法和Call类似。

分享到:
评论

相关推荐

    JavaScript上下文菜单控件

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

    Contextual.js:Javascript上下文菜单库

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

    js上下文理解

    在JavaScript中,**执行上下文**(Execution Context,简称EC)是理解程序执行过程的关键概念之一。每当代码执行时,都会创建一个新的执行上下文。根据不同的场景,执行上下文可以分为三种类型:全局执行上下文、...

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

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

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

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

    通过MOZILLA的javascript引擎(SpiderMonkey)执行js代码

    3. 使用`JS_NewContext`函数创建一个新的JavaScript上下文,每个上下文都关联了一个全局对象和执行环境。 4. 使用`JS_EvaluateScript`或`JS_EvaluateScriptForPrincipals`函数加载并执行JavaScript代码。 5. 在执行...

    利用文档工具检测PDF中的恶意Javascript

    - **静态文档检测**:对于每一个PDF中的JavaScript片段,系统会自动添加序言和结语,以便运行时检测器能够识别何时进入或退出JavaScript上下文。这种方法不受代码混淆的影响,同时也减少了开发工作量和计算开销。 - ...

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

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

    C调用javascript

    开发者可以通过`JS_Eval`函数执行JavaScript代码,并通过`JS_NewGlobalObject`创建独立的JavaScript上下文。 3. **使用Node.js的N-API**:Node.js是一个基于Chrome V8引擎的JavaScript运行环境。它的N-API(Native ...

    delphi与JavaScript进行交互,获取JS端返回值

    2. **加载JavaScript上下文**:创建一个JavaScript执行环境,通常是一个浏览器窗口或框架,加载你想要交互的JavaScript代码。 3. **调用JavaScript函数**:使用提供的API调用JavaScript函数,传入必要的参数。这...

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

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

    c++调用javascript代码

    通过V8的C++ API,可以创建JavaScript上下文、执行脚本、操作对象,并接收回调。 5. **JSC (JavaScriptCore)**:Apple的JavaScript引擎,常用于iOS和macOS开发。C++可以通过Objective-C++桥接来调用JSC,实现C++与...

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

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

    context-js:JavaScript 上下文菜单库

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

    深入浅析JavaScript中的作用域和上下文

    JavaScript中,作用域和上下文是理解代码执行逻辑的关键概念。作用域指的是变量和函数的可见性和生命周期,而上下文则关乎`this`关键字的值,它指示了当前代码执行的环境。 **作用域(Scope)** 1. **全局作用域**...

Global site tag (gtag.js) - Google Analytics