ng-cloak防止页面闪烁并且出现没有渲染的符号

本文介绍如何使用 AngularJS 的 ng-bind 和 ng-cloak 指令解决页面加载时未渲染内容的闪烁问题(Flash of Unrendered Content, FOUC)。通过这两种方法可以有效地提升用户体验。
10. ng-bind
尽管可以在视图中使用{{ }}模板语法(AngularJS内置的方式),我们也可以通过ng-bind
指令实现同样的行为。
<body ng-init="greeting='HelloWorld'">
<p ng-bind="greeting"></p>
</body>
在线示例: http://jsbin.com/esihUJ/1/edit。
HTML加载含有{{ }}语法的元素后并不会立刻渲染它们,导致未渲染内容闪烁(Flash of
Unrendered Content, FOUC)。我可以用ng-bind将内容同元素绑定在一起避免FOUC。内容会被
当作子文本节点渲染到含有ng-bind指令的元素内。
11. ng-cloak
除使用ng-bind来避免未渲染元素闪烁,还可以在含有{{ }}的元素上使用ng-cloak指令:
<body ng-init="greeting='HelloWorld'">
<p ng-cloak>{{ greeting }}</p>
</body>
ng-cloak指令会将内部元素隐藏,直到路由调用对应的页面时才显示出来。

 

 

### ### Vue 中 `v-cloak` 的工作原理 `v-cloak` 是 Vue 提供的一个内置指令,其核心作用是在 Vue 实例完成编译之前隐藏绑定的元素,从而防止页面加载时出现未渲染的模板内容。在页面首次加载时,浏览器会解析并渲染 HTML,但此时 Vue 尚未接管数据绑定,因此可能会显示类似 `{{ message }}` 这样的原始模板语法。这种现象通常被称为“闪烁”问题。 `v-cloak` 的工作流程如下: - 在 Vue 实例初始化时,它会扫描模板中的所有指令,包括 `v-cloak`。 - 在编译阶段,Vue 会将带有 `v-cloak` 的元素保留在 DOM 中,但不会更新其内容。 - 同时,Vue 会将这些元素的 `v-cloak` 属性保留在 DOM 上。 - 一旦 Vue 完成编译并成功更新数据绑定,`v-cloak` 属性将自动从 DOM 元素上移除。 - 此时,元素将显示经过 Vue 渲染后的真实内容。 ### ### `v-cloak` 如何防止页面闪烁 为了确保在 Vue 完成编译之前隐藏元素,通常需要配合 CSS 样式使用: ```css [v-cloak] { display: none; } ``` 上述 CSS 规则表示:只要元素带有 `v-cloak` 属性,浏览器就不会显示它。只有当 Vue 完成编译并将 `v-cloak` 属性移除后,元素才会按照正常的样式显示其内容。这样可以有效避免用户在页面加载初期看到未渲染的模板内容。 在某些情况下,例如使用了 `scoped` 样式或第三方库的样式时,为了确保 `v-cloak` 的样式优先级足够高,可以使用 `!important` 来增强其优先级: ```css [v-cloak] { display: none !important; } ``` 这种做法可以确保即使在复杂的样式环境中,`v-cloak` 依然能够生效[^3]。 ### ### 示例代码 以下是一个典型的 `v-cloak` 使用示例: ```html <template> <div v-cloak> <p>{{ blogName }}</p> <p>{{ blogUrl }}</p> </div> </template> <style scoped> [v-cloak] { display: none !important; } </style> <script setup> import { ref } from 'vue'; const blogName = ref('您好,欢迎访问 pan_junbiao的博客'); const blogUrl = ref('https://blog.youkuaiyun.com/pan_junbiao'); </script> ``` 在上述代码中,`v-cloak` 被应用于一个包含数据绑定的 `<div>` 元素。在 Vue 完成编译之前,该元素不会显示在页面上;编译完成后,`v-cloak` 被移除,元素将显示正确的数据内容。 ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值