【Vue】基础系列(十一)Vue指令-常用内置指令-自定义指令-全局指令-局部指令

1. 常用内置指令

  • v-text : 更新元素的 textContent
  • v-html : 更新元素的 innerHTML
  • v-if : 如果为true, 当前标签才会输出到页面
  • v-else: 如果为false, 当前标签才会输出到页面
  • v-show : 通过控制display样式来控制显示/隐藏
  • v-for : 遍历数组/对象
  • v-on : 绑定事件监听, 一般简写为@
  • v-bind : 强制绑定解析表达式, 可以省略v-bind
  • v-model : 双向数据绑定

  • v-text : 更新元素的 textContent
  1. 作用:向其所在的节点中渲染文本内容。
  2. 与插值语法的区别:v-text会替换掉节点中的内容,{ {xx}}则不会。

  • v-html : 更新元素的 innerHTML
  1. 作用:向指定节点中渲染包含html结构的内容。
  2. 与插值语法的区别:
    (1). v-html会替换掉节点中所有的内容,{ {xx}}则不会。
    (2). v-html可以识别html结构。
  3. 严重注意:v-html有安全性问题!!!!
    (1). 在网站上动态渲染任意HTML是非常危险的,容易导致XSS攻击。
    (2). 一定要在可信的内容上使用v-html,永不要用在用户提交的内容上!

  • v-once指令:
  1. v-once所在节点在初次动态渲染后,就视为静态内容了。
  2. 以后数据的改变不会引起v-once所在结构的更新,可以用于优化性能。

  • v-pre指令:
  1. 跳过其所在节点的编译过程。
  2. 可利用它跳过:没有使用指令语法、没有使用插值语法的节点,会加快编译。

  • ref : 为某个元素注册一个唯一标识, vue对象通过$refs属性访问这个元素对象

  • v-cloak : 使用它防止闪现表达式, 与css配合: [v-cloak] { display: none }

  1. 本质是一个特殊属性,Vue实例创建完毕并接管容器后,会删掉v-cloak属性。
  2. 使用css配合v-cloak可以解决网速慢时页面展示出{ {xxx}}的问题。
[v-clock] {
   
	display: none;
}
<body>
    <div id="demo">
        <p ref="content">baidu.com</p>
        <button @click="hint">提示</button>
        <p v-cloak>{
  {msg}}</p>
    </div>

    <script src="../js/vue.js"></script
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue中,自定义指令(Custom Directive)可以用来扩展元素的行为或提供一些特殊的交互功能。如果你想在`el-table-column`中使用自定义指令来设置`label`属性,首先你需要创建一个Vue自定义指令,然后将其应用到`el-table-column`的`label`属性上。 以下是一个简单的步骤说明: 1. **创建自定义指令**: 首先,定义一个名为`set-label`的自定义指令,例如: ```javascript Vue.directive('set-label', { bind: function (el, binding, vnode) { // 绑定指令时执行的逻辑 el.setAttribute('data-label', binding.value); // 将传递的值存储在DOM元素的data属性中 }, update: function (el, binding) { // 当绑定值变化时更新DOM el.textContent = binding.value; // 更新label文本 } }); ``` 2. **在模板中使用**: 在你的Vue组件中,将这个指令应用到`el-table-column`的`label`属性上: ```html <template> <el-table-column v-for="column in tableColumns" :key="column.field" :set-label="column.label" <!-- 使用自定义指令 --> :prop="column.field" :label="getCustomLabel(column.field)" <!-- 获取实际显示的label,可能从数据源动态计算 --> ></el-table-column> </template> ``` 3. **处理数据和逻辑**: 在组件内部,你需要有一个方法如`getCustomLabel`来根据实际情况返回正确的标签文本,可能需要查询数据源或者处理动态内容: ```javascript methods: { getCustomLabel(field) { // 根据字段名从数据源获取正确的标签文本,或者做其他处理 let label = this.data[field] || field; return label; } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值