热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

深入解析AngularJS表达式的应用与优化技巧

本文深入探讨了AngularJS表达式的应用及其优化策略。在AngularJS中,表达式主要通过$digest循环进行自动解析,但在某些场景下,手动解析表达式也是必要的。文章详细介绍了如何利用$parse服务实现手动解析,并提供了多种优化技巧,以提高应用性能和响应速度。

一:angularjs表达式的解析

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

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


"myApp">

"utf-8" />



"myController">


"expr" type="text" placeholder="表达式值" />


rrgffyy{{parseValue}}







这只是单纯的对页面上的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>

测试结果:

技术分享


推荐阅读
  • 本文探讨了在 SQL Server 中使用 JDBC 插入数据时遇到的问题。通过详细分析代码和数据库配置,提供了解决方案并解释了潜在的原因。 ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 深入解析动态代理模式:23种设计模式之三
    在设计模式中,动态代理模式是应用最为广泛的一种代理模式。它允许我们在运行时动态创建代理对象,并在调用方法时进行增强处理。本文将详细介绍动态代理的实现机制及其应用场景。 ... [详细]
  • Appium + Java 自动化测试中处理页面空白区域点击问题
    在进行移动应用自动化测试时,有时会遇到某些页面没有返回按钮,只能通过点击空白区域返回的情况。本文将探讨如何在Appium + Java环境中有效解决此类问题,并提供详细的解决方案。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 本文介绍如何使用MFC和ADO技术调用SQL Server中的存储过程,以查询指定小区在特定时间段内的通话统计数据。通过用户界面选择小区ID、开始时间和结束时间,系统将计算并展示小时级的通话量、拥塞率及半速率通话比例。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 在尝试使用C# Windows Forms客户端通过SignalR连接到ASP.NET服务器时,遇到了内部服务器错误(500)。本文将详细探讨问题的原因及解决方案。 ... [详细]
  • Python + Pytest 接口自动化测试中 Token 关联登录的实现方法
    本文将深入探讨 Python 和 Pytest 在接口自动化测试中如何实现 Token 关联登录,内容详尽、逻辑清晰,旨在帮助读者掌握这一关键技能。 ... [详细]
  • 通常情况下,修改my.cnf配置文件后需要重启MySQL服务才能使新参数生效。然而,通过特定命令可以在不重启服务的情况下实现配置的即时更新。本文将详细介绍如何在线调整MySQL配置,并验证其有效性。 ... [详细]
  • Python自动化测试入门:Selenium环境搭建
    本文详细介绍如何在Python环境中安装和配置Selenium,包括开发工具PyCharm的安装、Python环境的设置以及Selenium包的安装方法。此外,还提供了编写和运行第一个自动化测试脚本的步骤。 ... [详细]
  • 优化SQL Server批量数据插入存储过程的实现
    本文介绍了一种改进的SQL Server存储过程,用于生成批量插入语句。该方法不仅提高了性能,还支持单行和多行模式,适用于SQL Server 2005及以上版本。 ... [详细]
  • 本文介绍了如何通过Java代码计算一个整数的位数,并展示了多个基础编程示例,包括求和、平均分计算、条件判断等。 ... [详细]
author-avatar
mobiledu2502856483
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有