angular 数据绑定之[]和{{}}的区别
问题描述
在学习angular时,在示例代码写到加载图片时,书中推荐使用单向数据绑定符号[]来绑定图片的路径,然后双花括号的写法是错的。
尝试
首先,按书中推荐的写法:
<img [src]="imgUrl" />
这里就省略了控制器中定义变量的代码。
然后又按书中说错误的方式进行尝试:
<img src="{{ imgUrl }}" />
最后的测试结果发现两种写法都可以正常加载图片,并没有出现将{{ imgUrl }}解析成字符串的问题。
重读
发现没有达到预期的效果,所以就又重新看了一下书中是怎么说的:
如果浏览器在Angular运行起来之前就加载了这段模板,就会尝试以字符串{{ imgUrl }}为Url来加载图片,这当然会得到一个“404 Not found”错误。在Angular运行起来之前,浏览器会在页面显示一个破损的图像。
仔细读了上面的原文,发现出现错误是有条件的。那什么时候才会触发上面的错误呢?
猜测
联想到angularjs中的双花括号,与angular类似,之前在使用的时候就会出现变量没有被正常加载的问题,导致页面直接显示{{...}}的现象。当时出现这种问题是在加载缓慢,或者重复刷新。原因就是模板加载完成了,但是angularjs并没有加载完全。
所以,我就大胆猜测,当angular加载缓慢的时候,{{}}的写法就会出现问题。
(这里笔者经过几次尝试,并没有出现问题。如果有人尝试出,欢迎指正。)
两种绑定的区别
使用[]和{{}}的区别并不大,两者都是一种angular中的单向绑定实现方式,却别就是使用{{}}的形式,会将括号中的表达式解析完成后,再将结果转换成字符串。而[]不会转换成字符串。
总结
有些问题可能以我们目前的水平并不能很好的解释,但是做出一个令自己信服的猜测还是很容易的。哪怕这个猜测在未来的某一天被证实是错误的,那只会是你新的积累的开始。
上一篇:AngularJS基于factory创建自定义服务的方法详解
栏 目:AngularJS
下一篇:AngularJS出现$http异步后台无法获取请求参数问题的解决方法
本文地址:http://www.codeinn.net/misctech/44378.html