vue中的与,或,非

核心概念:Vue 模板中的逻辑运算

在 Vue 的模板中,我们经常需要根据条件来显示或隐藏内容、动态绑定类名和样式等。这时就会用到 JavaScript 的逻辑运算符:&& (与)、|| (或)、! (非)。

这些运算符在 Vue 模板中的工作方式与在纯 JavaScript 中完全一致。


1. 与 (AND) - &&

  • 功能:只有当两个操作数都为真值时,整个表达式才返回真。如果第一个操作数为假,则直接返回第一个操作数的值( falsy value );否则返回第二个操作数的值。

  • 模板中的应用 :常用于条件渲染。例如,"当某个条件成立时,才渲染某个元素"。

    <template>

    欢迎,{{ user.name }}!

    请登录

    复制代码
      <!-- 另一个例子:当数据加载完成且有数据时才显示列表 -->
      <ul v-if="!loading && items.length">
        <li v-for="item in items" :key="item.id">{{ item.title }}</li>
      </ul>
      <p v-else-if="loading">加载中...</p>
      <p v-else>暂无数据</p>
    </div>
    </template> <script> export default { data() { return { user: { loggedIn: true, name: '张三' }, loading: false, items: [{ id: 1, title: '项目1' }] }; } }; </script>

页面展示


2. 或 (OR) - ||

  • 功能:如果第一个操作数为真,则返回第一个操作数的值;否则返回第二个操作数的值。

  • 模板中的应用 :常用于提供默认值多条件判断

    <template>

    你好,{{ user.name || '游客' }}!

    复制代码
      <!-- 多条件判断:用户是管理员或内容编辑者时,显示管理面板 -->
      <div v-if="user.role === 'admin' || user.role === 'editor'">
        <button>管理面板</button>
      </div>
    </div>
    </template> <script> export default { data() { return { user: { name: '', // 空名字,会触发默认值 role: 'editor' } }; } }; </script>

页面展示


3. 非 (NOT) - !

  • 功能 :取反操作。如果操作数为真,则返回 false;如果为假,则返回 true

  • 模板中的应用 :常用于取反条件

    <template>

    内容加载完成!

    加载中...
    复制代码
      <!-- 当用户未认证时,显示登录按钮 -->
      <button v-if="!isAuthenticated">登录</button>
      <button v-else>退出</button>
    </div>
    </template> <script> export default { data() { return { loading: true, isAuthenticated: false }; } }; </script>

页面展示

相关推荐
IT_陈寒4 分钟前
Python 3.12 新特性实战:10个让你代码更优雅的隐藏技巧
前端·人工智能·后端
一 乐25 分钟前
海产品销售系统|海鲜商城购物|基于SprinBoot+vue的海鲜商城系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·后端
艾小码25 分钟前
还在死磕模板语法?Vue渲染函数+JSX让你开发效率翻倍!
前端·javascript·vue.js
炒毛豆26 分钟前
vue3 + antd + print-js 实现打印功能(含输出PDF)
前端·javascript·vue.js
天天向上102427 分钟前
el-table动态添加行,删除行
前端·javascript·vue.js
小王码农记1 小时前
vue2中实现天气预报
前端·javascript·vue.js·echarts
我命由我123451 小时前
Element Plus 组件库 - Select 选择器 value 为 index 时的一些问题
开发语言·前端·javascript·vue.js·html·ecmascript·js
一念一花一世界1 小时前
Arbess从初级到进阶(2) - 使用Arbess+GitLab实现Vue.js项目自动化部署
vue.js·ci/cd·gitlab·arbess
qq. 28040339842 小时前
js 原型链分析
开发语言·javascript·ecmascript
有趣的野鸭2 小时前
JAVA课程十一次实验课程主要知识点示例
java·前端·数据库