Angularjs Scope 原型链

我们知道scope是可以继承的.scope的继承和js原型链是同一个概念。

    <div ng-controller="parentCtrl">
        {{name}}
       <div ng-controller="childCtrl">
           {{name}}
       </div>
    </div>

在angular中,ng-controller指令会帮我们创建一个scope并继承它的父亲scope .

parentCtrl scope继承自 $rootScope , childCtrl scope 继承自parent scope.

app.controller("parentCtrl", function ($scope,$rootScope) {
    $scope.name = "keatkeat";
});
app.controller("childCtrl", function ($scope) {

});

所以即使我们在childCtrl没有给 name 赋值,模板依然可以从parentCtrl 读取到"keatkeat".

继承对于子层读取父亲属性值非常良好和简单。但是在写就不那么方便了!

比如

app.controller("childCtrl", function ($scope) {
    $scope.name = "xinyao";
});

当我们在子层填"xinyao"时,你会发现这个值确实在子层的模板出现了,而父亲模板依旧是原来的"keatkeat"

孩子可以覆盖父亲,这也许是我们想要的。

但也有这种情况

app.controller("parentCtrl", function ($scope,$rootScope) {
    $scope.name = {
        first: "keat",
        last: "keat"
    }
});
app.controller("childCtrl", function ($scope) {
    $scope.name.first = "xin";
    $scope.name.last = "yao";
});

当父亲的值是个对象时,就要特别小心了。$scope.name.first = "xin"; 会修改掉父亲的值!

所以对于原型链来说,孩子是有"机会"修改掉父亲的值的。

如果你不熟悉js 可能会不太能理解,其实原理是很简单的

你可以把 $scope.name.first = "xin"; 看成这样

var obj = $scope.name; //读取name属性,在子层没有,所以会去父层找,并且找到了一个对象

obj.first = "xin";  //你写入的自然是父层的对象咯,所以也就覆盖了父亲啦 .

这其实也挺好的!善加利用的话,孩子可以修改父亲的值也很方便。

那么是不是只有对象才可能这样呢。

如果只是 $scope.name = "keatkeat"; 就不可能被子层修改了吗?

大部分情况是!但是也有例外!

比如

app.controller("parentCtrl", function ($scope, $rootScope) {
    var _name = "keatkeat";
    Object.defineProperty($scope, "name", {
        get: function () { return _name },
        set: function (newValue) { _name = newValue }
    });
});
app.controller("childCtrl", function ($scope) {
    $scope.name = "xinyao";
});

父亲的name是加了setter的属性, object.defineProperty是ECMA5 的新功能。

一但这样,孩子就无法在添加自己的name属性了,它会直接调用父亲的name做读写!

善加利用的话还是不错的!

总结 : angularjs的scope是单纯的js对象,继承也是单纯的js继承(原型链),所以呢不要感觉它很神奇很神秘,你要去了解它才能把它发挥出来 ^^

时间: 2024-10-13 12:03:58

Angularjs Scope 原型链的相关文章

闭包,原型链

闭包 在[函数定义]的时候,[函数对象]的[scope属性]便会引用包含该函数的上一级函数在运行时所生成的[执行上下文]的[活动对象],因为发生对象属性之间的相互依赖,导致包含此函数的[scope属性]所指向的活动变量,在上一级函数[执行完毕]将要[释放执行上下文]的时候[不能释放]其包含的[活动变量]. 自己的理解: 闭包的产生首先要有一个地址被引用所指向 函数与对象的关系 函数就是对象的一种 对象是函数创建的 prototype原型 prototype是函数的一个属性 每一个构造函数都有pr

原型、原型链、闭包、继承

一.原型.原型链 原型对象    在JavaScript 中,每当定义一个对象(函数)时候,对象中都会包含一些预定义的属性.其中函数对象的一个属性就是原型对象 prototype.注:普通对象没有prototype,但有__proto__属性. 原型对象其实就是普通对象(Function.prototype除外,它是函数对象,但它很特殊,他没有prototype属性(前面说道函数对象都有prototype属性)).看下面的例子:  function f1(){};  console.log(f1

1、AJAX里面status的值代表什么 2、get post 的区别 3、怎样把对象转化成字符串 4、闭包、继承、原型、原型链 5 、http传输协议 6、arguments是什么

1.AJAX里面status的值代表什么     在JavaScript里面写AJax的时,最关键的一步是对XMLHttpRequest对象建立监听,即使用"onreadystatechange"方法.监听的时候,要对XMLHttpRequest对象的请求状态进行判断,通常是判断readyState的值为4且status的值为200或者304时执行我们需要的操作.以下记录了一些常用readState以及status的值及其含义 readyState 属性表示Ajax请求的当前状态.它的

作用域、原型链、闭包等概念理解

1.执行环境及作用域 (1).执行环境: 定义了变量或函数有权访问的其它数据,决定了它们的各自行为.每个执行环境都有一个与之关联的变量对象(variable object, VO),执行环境中定义的所有变量和函数都会保存在这个对象中,解析器在处理数据的时候就会访问这个内部对象. 全局执行环境是最外层的一个执行环境,在web浏览器中全局执行环境是window对象,因此所有全局变量和函数都是作为window对象的属性和方法创建的.每个函数都有自己的执行环境,当执行流进入一个函数的时候,函数的环境会被

作用域链、闭包和原型链

Function:  匿名函数,作用域,作用域链和闭包 函数的重载:  什么是:函数名相同,参数列表不同.根据传入函数的参数的不同,整形不同的逻辑. 何时用:如果一项任务,根据不同的参数,不执行不用的逻辑. 优点:减轻调用者的负担.  问题:js语法不知函数的重载. 解决办法:在函数中都有arguments的属性,专门用于接收传入函数的所有参数值的类数组对象. 匿名函数:  什么是:在函数定义时,不给函数名,即不被任何变量引用. 何时用:确定函数只使用一次.  优点:节约内存. 如何用:1.自调

标识符解析、作用域链、运行期上下文、原型链、闭包

本文讲到的是如何从数据访问层面上提高JS 代码的执行效率.总的来讲有以下几条原则: 函数中读写局部变量总是最快的,而全局变量的读取则是最慢的: 尽可能地少用with 语句,因为它会增加with 语句以外的数据的访问代价: 闭包尽管强大,但不可滥用,否则会影响到执行速度以及内存: 嵌套的对象成员会明显影响性能,尽量少用: 避免多次访问对象成员或函数中的全局变量,尽量将它们赋值给局部变量以缓存. 这么几句话看似简单,但要深刻理解其中的道理则需涉及到JS的 标识符解析.作用域链.运行期上下文(又称为执

通过原型链解析js函数一些难以理解的的作用域问题

基本原理 js函数在执行时,系统会创建一个隐式的属性scope,scope中存储的是函数的作用域链. 通过对这个scope的分析,就能解释JavaScript中许多难以理解的问题: 例1: function demo(){} demo(); scope属性是在函数执行时创建,如果这个函数是一个全局函数,他的scope里会保存一个Global object和一个activation object. global object保存的是全局的信息,而activition object保存的是函数内部的

js的原型链

开篇 之前对js中的原型链和原型对象有所了解,每当别人问我什么是原型链和原型对象时,我总是用很官方(其实自己不懂)的解释去描述.有一句话说的好:如果你不能把一个很复杂的东西用最简单的话语描述出来,那就说明你没有真正的理解.最近正在读<Javascript高级程序设计>,书中对原型对象和原型链的描述让我受益匪浅,下面仅用一个对比性的例子来说明. 我们经常会这么写 function Person () { this.name = 'John'; } var person = new Person(

javascript中的构造函数和原型及原型链

纯属个人理解,有错误的地方希望大牛指出,以免误人子弟 1.构造函数: 构造函数的作用 : 初始化由new创建出来的对象    new 的作用: 创建对象(空对象) new 后面跟的是函数调用,使用new来调用函数,跟普通的直接调用函数主要的不同: 就是 this 的指向不同了 , 再就是 会自动的返回新创建的对象 什么是原型?        原型的作用:就是为了实现继承!  一个对象的原型就是它的构造函数的prototype属性的值. 在讨论原型的时候,是指的 对象和原型对关系 prototyp