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>

页面展示

相关推荐
球球pick小樱花1 天前
游戏官网前端工具库:海内外案例解析
前端·javascript·css
前端Hardy1 天前
干掉 Virtual DOM?尤雨溪开始"强推" Vapor Mode?
vue.js·vue-router
用户60572374873081 天前
AI 编码助手的规范驱动开发 - OpenSpec 初探
前端·后端·程序员
狗胜1 天前
AI观察日记 2026-03-02|CLAUDE、TYPE、APPFUNCTIONS:掘金热门里的下一步信号
前端
喝水的长颈鹿1 天前
【大白话前端 02】网页从解析到绘制的全流程
前端·javascript
明君879971 天前
Flutter 实现 AI 聊天页面 —— 记一次 Markdown 数学公式显示的踩坑之旅
前端·flutter
用户14536981458781 天前
VersionCheck.js - 让前端版本更新变得简单优雅
前端·javascript
米饭同学i1 天前
微信小程序实现随机撒花效果
前端
Arthur14726122865471 天前
模块化和组件化的区别
前端
codingWhat1 天前
整理「祖传」代码,就是在开发脚手架?
前端·javascript·node.js