zoukankan      html  css  js  c++  java
  • angularjs之表达式

    一:angularjs表达式的解析

    angularjs会在运行$digest循环中自动解析表达式,但有时手动解析表达式也是非常用用的.

    angularjs通过$parse这个内部服务来进行表达式的运算,这个服务能够访问当前所处的作用于,这个过程允许我们访问定义在$scope上的原始javascript数据和函数.

    <!DOCTYPE html>
    <html ng-app="myApp">
        <head>
            <meta charset="utf-8" />
            <title></title>
        </head>
        <body>
            <div ng-controller="myController">
                <p>
                    <input ng-model="expr" type="text" placeholder="表达式值" />    
                </p>
                <pre>rrgffyy{{parseValue}}</pre>
                
            </div>
        </body>
        <script type="text/javascript" src="js/angularJs-1.2.16-min.js" ></script>
        <script type="text/javascript">
            angular.module("myApp",[])
            .controller("myController",function($scope,$parse){
                $scope.$watch("expr",function(newVal,oldVal,scope){
                    if(newVal!=oldVal){
                        //用该表达式设置parseFun
                        var parseFun=$parse("expr");
                        //获取经过解析后表达式的值
                        $scope.parseValue=parseFun(scope);
                    }
                });
            })
        </script>
    </html>

    这只是单纯的对页面上的angular表达式解析,但是有时候我们想要对一段字符串进行解析,将字符串中的angularjs表达式解析成我们需要的值.如何做呢.

    二:解析字符串.

    在字符串模版中做表达式的解析,需要在你的对象中注入$interpolate服务.

    $interpolate(text,mustHaveExpression,trustedContext)服务是一个可以接受三个参数的字符串.

    text(字符串):字符串模板

    mustHaveExpression(布尔值):如果这个值是true,当传入的字符串中不含有表达式时会返回null

    trustedContext(字符串):angularJs会对已经进行过字符串插值操作的字符串通过$sec.getTrusted()方法严格的上下文转义.

    $interpolate服务返回一个函数,用来在特定的上下文中运算表达式.

    <!DOCTYPE html>
    <html ng-app="myApp">
        <head>
            <meta charset="utf-8" />
            <title></title>
        </head>
        <body>
            <div ng-controller="myController">
                <p>
                    <input ng-model="name" type="text" placeholder="姓名" />    
                </p>
                <pre>{{previewText}}</pre>
                
            </div>
        </body>
        <script type="text/javascript" src="js/angularJs-1.2.16-min.js" ></script>
        <script type="text/javascript">
            angular.module("myApp",[])
            .controller("myController",function($scope,$interpolate){
                var strTempl="大家好,我是{{name}}";
                $scope.$watch("name",function(name){
                    if(name){
                        var template=$interpolate(strTempl);
                        $scope.previewText=template({name:$scope.name});
                    }
                });
            });
        </script>
    </html>

    看看测试:

    我们成功的对

    var strTempl="大家好,我是{{name}}"

    完成了解析.

    利用这个原理我们来看一个更复杂一点的例子.

    让我们的字符串模板是动态的.

    <!DOCTYPE html>
    <html ng-app="myApp">
        <head>
            <meta charset="utf-8" />
            <title></title>
        </head>
        <body>
            <div ng-controller="myController">
                <p>
                    <input ng-model="name" type="text" placeholder="姓名" />    
                </p>
                <p>
                    <input ng-model="age" type="text" placeholder="年龄" />    
                </p>
                <textarea ng-model="strTempl"></textarea>
                <pre>{{previewText}}</pre>
                
            </div>
        </body>
        <script type="text/javascript" src="js/angularJs-1.2.16-min.js" ></script>
        <script type="text/javascript" >
        angular.module("myApp",[])
    .controller("myController",function($scope,$interpolate){
        var strTempl="大家好,我是{{name}}"
        $scope.$watch("strTempl",function(strTempl){
            if(strTempl){
                var template=$interpolate(strTempl);
                $scope.previewText=template({name:$scope.name,age:$scope.age});
            }
        });
    });
        </script>
    </html>
        

    测试结果:

    按照angularjs的编写规范,这里的字符串解析完全可以提取成一个服务.

    <!DOCTYPE html>
    <html ng-app="myApp">
        <head>
            <meta charset="utf-8" />
            <title></title>
        </head>
        <body>
            <div ng-controller="myController">
                <p>
                    <input ng-model="name" type="text" placeholder="姓名" />    
                </p>
                <p>
                    <input ng-model="age" type="text" placeholder="年龄" />    
                </p>
                <textarea ng-model="strTempl"></textarea>
                <pre>{{previewText}}</pre>
                
            </div>
        </body>
        <script type="text/javascript" src="js/angularJs-1.2.16-min.js" ></script>
        <script type="text/javascript">
        angular.module("emailParser",[])
    .factory("EmailParser",["$interpolate",function($interpolate){
        return {
            parse:function(text,context){
                var template=$interpolate(text);
                return template(context);
            }
        }
    }]);
    angular.module("myApp",["emailParser"])
    .controller("myController",["$scope","EmailParser",function($scope,EmailParser){
        $scope.$watch("strTempl",function(body){
            if(body){
                $scope.previewText=EmailParser.parse(body,{name:$scope.name,age:$scope.age});
            }
        });
    }]);
    
        </script>
    </html>

    三.修改表达式的表示符

    angularjs默认的表达式表示方法是:{{name}},双括号.

    我现在要改成这样的.#{name};

    <!DOCTYPE html>
    <html ng-app="myApp">
        <head>
            <meta charset="utf-8" />
            <title></title>
        </head>
        <body>
            <div ng-controller="myController">
                <p>
                    <input ng-model="name" type="text" placeholder="姓名" />    
                </p>
                <p>
                    <input ng-model="age" type="text" placeholder="年龄" />    
                </p>
                <textarea ng-model="strTempl"></textarea>
                <pre>#{previewText}</pre>
                
            </div>
        </body>
        <script type="text/javascript" src="js/angularJs-1.2.16-min.js" ></script>
        <script type="text/javascript">
        angular.module("emailParser",[])
        .config(["$interpolateProvider",function($interpolateProvider){
        $interpolateProvider.startSymbol("#{");
        $interpolateProvider.endSymbol("}");
    }])
    .factory("EmailParser",["$interpolate",function($interpolate){
        return {
            parse:function(text,context){
                var template=$interpolate(text);
                return template(context);
            }
        }
    }]);
    angular.module("myApp",["emailParser"])
    .controller("myController",["$scope","EmailParser",function($scope,EmailParser){
        $scope.$watch("strTempl",function(body){
            if(body){
                $scope.previewText=EmailParser.parse(body,{name:$scope.name,age:$scope.age});
            }
        });
    }]);
    
        </script>
    </html>

    测试结果:

  • 相关阅读:
    JStorm开发经验+运维经验总结
    Storm-166:Nimbus HA solution based on Zookeeper
    Storm实战集锦
    JStorm之Nimbus简介
    BF算法 + KMP算法
    分布式消息系统:Kafka
    分布式服务框架:Zookeeper简介
    修改JSONArray里所有key的值
    JQuery中$.ajax()方法参数详解
    java利用16进制来辨别png格式的图片
  • 原文地址:https://www.cnblogs.com/guoyansi19900907/p/5173062.html
Copyright © 2011-2022 走看看