首页 > 网站 > WEB开发 > 正文

$parse , $interpolate ,$complie , $destroy

2024-04-27 14:20:04
字体:
来源:转载
供稿:网友

$parse , $interpolate ,$complie , $destroy

$parse 是angular 提供的javascript解析器 .

var getter = $parse(exPRession);

var setter = getter.assign;

                    controller("ctrl", ["$scope", "$parse", "$compile", "$interpolate", function ($scope, $parse, $compile, $interpolate) {                        //read                        $scope.name = "hello";                        var expression = "name + ' ' +((5+6) == (12-1))";                                              var getter = $parse(expression);                        var value = getter($scope); //hello true                           //write                        expression = "name";               var setter = getter.assign;                       setter($scope, "1782");                            $scope.name; //1782                                               }]);

有点像Javascript eval 和 with 的结合。内部是通过复杂的正则实现的。

$parse 无法解析angular 的 {{}} 符合。

所以当我们需要解析如 {{name}} 时, 我们会用 $interpolate

                        $scope.name = "hello";                        var expression = "{{name}}";                        var value = $interpolate(expression)($scope); //没有setter的方法哦                        console.log(value);

$compile 是用来处理html 节点的 . 要注意的是 $compile('str')($scope) = node; 这个node要在digest之后才会有scope value, ng-repeat同理,没有digest连一行都看不见,只有comment记号。

                        $scope.name = "hello"                        var link = $compile("<div>{{name}}</div>");                        var node = link($scope);                        console.log(node[0].innerHTML); //{{name}} <--还没同步值                        setTimeout(function () {                            console.log(node[0].innerHTML); //hello <--同步咯                        }, 0); //推迟到$digest之后

$compile 要注意的事 :

var elemA = $compile(directiveA)(scopeA);

1.elemA 的 scope 一定是scopeA , 即使directiveA使用了隔离scope.(elemA的child才是隔离的scope)

2.如果 directiveA 内有require, 那是不对的,会报错, 指令有require 那么它必须和它的依赖指令一起compile

3.$compile 不依赖elem的格局, 它只在乎scope, 所以elemA 你可以append到任意的地方,scope改变view依然会改变

4.scope 属于模板,所以你compile的这个scope应该是只属于这个模板的,当模板被remove,你的scope理应一同被remove.

5.template 不能被 compile 超过一次,同理 scope 也是一样 (不要想着一个scope compile 多个模板 , 记得 scope 属于模板而不是控制器 !)

6.remove 或 html('') 删除模板时, 记得调用 $elem.scope().$destroy(); scope一样删除.

7. 一般上只有在做动态模板的时候我们才会自己调用 $compile, 大部分情况下我们还是简单实用指令,模板,控制器就好 ^^

其实在angualr中最好是用 $timeout(fn,time,need_digest). 第3个参数让我们觉得之后要不要digest多一次.


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表