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>

页面展示

相关推荐
集成显卡4 小时前
Bun v1.3.6 发布:内置 Tarball 归档支持、JSONC 解析、Bundle 分析增强等重磅更新!
javascript·新版本·bun.js
奔跑的web.5 小时前
TypeScript Enum 类型入门:从基础到实战
前端·javascript·typescript
盐真卿5 小时前
python2
java·前端·javascript
梦梦代码精5 小时前
BuildingAI vs Dify vs 扣子:三大开源智能体平台架构风格对比
开发语言·前端·数据库·后端·架构·开源·推荐算法
刘一说5 小时前
Vue3 组合式 API(Composition API):逻辑复用的革命性实践
vue.js·vue
seabirdssss6 小时前
《bootstrap is not defined 导致“获取配置详情失败”?一次前端踩坑实录》
前端·bootstrap·html
kgduu6 小时前
js之表单
开发语言·前端·javascript
摘星编程7 小时前
React Native for OpenHarmony 实战:Picker 选择器组件详解
javascript·react native·react.js
摘星编程8 小时前
React Native for OpenHarmony 实战:VirtualizedList 虚拟化列表
javascript·react native·react.js
谢尔登8 小时前
Vue3 响应式系统——computed 和 watch
前端·架构