angular 数据绑定之[]和{{}}
问题描述
在学习angular
时,在示例代码写到加载图片时,书中推荐使用单向数据绑定符号[]
来绑定图片的路径,然后双花括号的写法是错的。
尝试
首先,按书中推荐的写法:
<img [src]="imgUrl" />
这里就省略了控制器中定义变量的代码。
然后又按书中说错误的方式进行尝试:
<img src="{{ imgUrl }}" />
最后的测试结果发现两种写法都可以正常加载图片,并没有出现将{{ imgUrl }}
解析成字符串的问题。
重读
发现没有达到预期的效果,所以就又重新看了一下书中是怎么说的:
如果浏览器在Angular运行起来之前
就加载了这段模板,就会尝试以字符串{{ imgUrl }}
为Url来加载图片,这当然会得到一个“404 Not found”错误。在Angular运行起来之前,浏览器会在页面显示一个破损的图像。
仔细读了上面的原文,发现出现错误是有条件的。那什么时候才会触发上面的错误呢?
猜测
联想到angularjs
中的双花括号,与angular类似,之前在使用的时候就会出现变量没有被正常加载的问题,导致页面直接显示{{...}}
的现象。当时出现这种问题是在加载缓慢,或者重复刷新。原因就是模板加载完成了,但是angularjs并没有加载完全。
所以,我就大胆猜测,当angular
加载缓慢的时候,{{}}
的写法就会出现问题。
(这里笔者经过几次尝试,并没有出现问题。如果有人尝试出,欢迎指正。)
两种绑定的区别
使用[]
和{{}}
的区别并不大,两者都是一种angular中的单向绑定实现方式,却别就是使用{{}}
的形式,会将括号中的表达式解析完成后,再将结果转换成字符串。而[]
不会转换成字符串。
总结
有些问题可能以我们目前的水平并不能很好的解释,但是做出一个令自己信服的猜测还是很容易的。哪怕这个猜测在未来的某一天被证实是错误的,那只会是你新的积累的开始。
朴世超
个人学习总结与项目实战问题记录
345 声望
21 粉丝
推荐阅读
多神经元简单神经网络的实现
数据集首先数据集选择使用Cifar-10。这个数据集合包含十个类的图片,每类6000张32 x 32的图片,共计60000张图片,其中50000训练图片,10000张测试图片。这里下载了python对应的版本:读取文件在Cifar-10的网站,...
喵先生的进阶之路赞 1阅读 1.4k
使用springboot+angular实现web端微信扫码登陆
现在微信的使用用户越来越多,如果网站添加上微信登录,就能节省很多用户注册时间,极大缩小了注册流程。会让用户觉得特别方便。接下来我们就说一下怎么来实现Web端微信扫码登录。
郝泽龙_HZ赞 6阅读 915
解决angular 报错 url unsafe
遇到报错使用的img 标签出现了报错 {代码...} 报错这个url 为 unsafeXSS首先先了解为什么会出现unsafe为了系统性的防范 XSS 问题,Angular 默认把所有值都当做不可信任的。即 unsafe跨站脚本(XSS)允许攻击者将恶...
weiweiyi赞 3阅读 379
实现第三方登陆:微信扫码登录 (spring boot)
前言各种官方网站通常都会有app、微信公众号等。比如央视网,银行等。当我们关注公众号或者app后,这些应用就可以在移动端方便地将信息推送给用户。统一各产品线的账号体系,实现一个账号处处使用的目标是非常有...
weiweiyi赞 4阅读 582
Async Pipe 以及Promise
前言之前在写项目的时候引用某个管道的时候 <td>{{ house | housePlace }}发现效果不是想要的, 而是如下图的效果,并没有显示出正确的地址!参考项目中的代码发现需要加上async管道 <td>{{ house | h...
weiweiyi赞 2阅读 947
记一个angular在路由配置中管理 Angular Material Dialog(实现动态组件的弹窗显示)
我们的目标正如标题所言:在路由配置中管理 Angular Material Dialog,从而更简便(代码量更少,可复用性,可拓展性、可维护性更强)地实现动态组件的弹窗显示。不难看出,我们的目标由两个部分组成,动态组件和...
HHepan赞 5阅读 323评论 2
Service Worker 在 PWA 中的应用
在 Samsung Internet 中,有一个称为 ambient badging 的功能。 如果浏览器检测到该页面是 PWA,它会动态更新 URL 栏中常用的书签图标,将其更新为特殊的 + 图标,为用户提供一个简单的快捷方式将其添加到他们的...
JerryWang_汪子熙阅读 909
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。