Angular页面里元素class的动态绑定的实现源代码调试
2021-02-20 本文已影响0人
华山令狐冲
例子:考虑这行代码:
[class.is-current]="isCurrentItem(item)"
如果函数isCurrentItem(item)返回true,则tr标签会被分配is-current class.
data:image/s3,"s3://crabby-images/13cb3/13cb36b6ce456339dc92abbba99ce0a2bf995788" alt=""
isCurrentItem的计算逻辑:
/**
* Indicates whether the given item is the current item.
*
* The current item is driven by the `currentItem`, that holds a
* property and value to compare.
*/
isCurrentItem(item: any): boolean {
if (!this.currentItem || !this.currentItem.value) {
return false;
}
return this.currentItem?.value === item?.[this.currentItem?.property];
}
什么时候给这个tr标签分配的is-current class?
data:image/s3,"s3://crabby-images/cfd8f/cfd8f07e81a900ecb05ac5983e857f0555a952b6" alt=""
在core.js的函数ɵɵclassProp里设置断点进行调试即可:
data:image/s3,"s3://crabby-images/e4a30/e4a304b39541a4ec0a91636a2cc8aa8f49c32a4d" alt=""
下面这段代码给tr标签赋上is-current的class:
data:image/s3,"s3://crabby-images/a0e7a/a0e7a4484312ce86d194e1c95ef4dbd81f9cd5da" alt=""
data:image/s3,"s3://crabby-images/46002/4600220c5c5972fa3383afc0697c123837ee3718" alt=""
最后在platform-browser.js里调用浏览器原生的html元素的classList属性的add方法,添加新的is-current类:
data:image/s3,"s3://crabby-images/f007e/f007e0cecaaefe60cc2422fa8bc2d83790e5e4ad" alt=""
同样值得关注的函数还有ɵɵstyleProp.
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/5c245/5c2451227ab390a16b5fe9bdbec5d83178d7661c" alt=""