javascript - angular.js 中的双花括号{{}}问题
问题描述
<p ng-controller='listCtrl'> <h1>这是列表页面</h1> <ul><li ng-repeat='item in myList'><a href='https://www.haobala.com/wenda/13666.html#/myDetail/{{$index}}'>{{item}}</a></li><li ng-repeat='item in myList'><button ng-click='jump(’/myDetail/’+$index)'>{{item}}</button></li> </ul></p>
如题,如上的代码中,我需要取到$index值作为参数,在第一个li中需要加{{}}才能取到值,而第二个li中不需要加;这个该如何区分??
问题解答
回答1:在原生html里面为了解析数据,需要使用{{}}来绑定数据,而ng的命令后面没有这需要。
回答2:{{ $var }}包裹的模板变量,当需要直接输出变量值,而无需额外解析(如过滤器处理、作为指令参数、作为函数参数)时使用,反之,ng-click='jump(’/myDetail/’+ $index)' 是在指令中调用的参数。
回答3:简单的判定标准就是
如果当前属性所赋值的类型为字面量类型,比如html模板中的属性,或者指令中以@为修饰符的属性,那么赋值的时候如果不加双花括号,均是按字面量来算的,想要按变量的方式解析,就需要加双花括号。
如果当前属性所赋值的类型是非字符串类型,比如angular模板中的各种内置指令,或者指令中以<、=、&修饰的属性,那么赋值的时候会按js的语法规则进行解析,这种情况就不需要加花括号了。
回答4:先说明下Angular中的两种类型:
模板:格式为{{...}},实质是字符串,会被解析引擎展开成可以识别的字符串文本表达式:可以直接运行的代码,和JS写法基本一致,只是省略了所有的this。
然后你可以参照一下上下文,确定你现在是在写类似JS的部分,还是在写一个字符串文本,这样就容易判断你是需要模板还是表达式了。
相关文章:
1. 为什么span的color非要内联样式才起作用?2. javascript - swiper.js嵌套了swiper 初始设置不能向下一个滑动 结束后重新初始3. angular.js - angular-ui-bootstrap 报错无法使用?4. docker - 如何修改运行中容器的配置5. 高并发写入和更新mysql6. 如何使用git对word文档进行版本控制?7. 在cmd下进入mysql数据库,可以输入中文,但是查看表信息,不显示中文,是怎么回事,怎新手,请老师8. javascript - 关于<a>元素与<input>元素的JS事件运行问题9. 请问一下各位老鸟 我一直在学习独孤九贱 现在是在tp5 今天发现 这个系列视频没有实战10. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?

网公网安备