vue.js 实践--侦听器和样式绑定

目录

一、侦听器

1、什么是侦听器

2、用法演示

[二、样式绑定 class](#二、样式绑定 class)

[2.1 将class属性值绑定为字符串](#2.1 将class属性值绑定为字符串)

[2.2 将class属性值绑定为对象](#2.2 将class属性值绑定为对象)

[2.3 将class属性值绑定为数组](#2.3 将class属性值绑定为数组)

三、样式绑定style

[3.1 将style属性值绑定为对象](#3.1 将style属性值绑定为对象)

[3.2 将style属性绑定为数组](#3.2 将style属性绑定为数组)

四、知识点补充

[4.1 class 和style的区别](#4.1 class 和style的区别)

[4.2 三元表达式](#4.2 三元表达式)


一、侦听器

1、什么是侦听器

2、用法演示

复制代码
<template>
  <!-- 输入框,输入内容会自动同步给 cityName -->
  <input type="text" v-model="cityName">
</template>

<script setup>
// 引入需要的 API
import { watch, ref } from 'vue'

// 定义响应式变量,默认值 beijing
const cityName = ref('beijing')

// 监听响应式数据变化
watch(cityName, (newVal, oldVal) => {
  // 新值,旧值
  console.log(newVal, oldVal)
})
</script>

效果

二、样式绑定 class

2.1 将class属性值绑定为字符串

复制代码
<template>
  <div v-bind:class="className">梦想</div>
</template>
<script setup>
const className = 'box'
</script>

<style>
.box {
  border: 10px solid rgb(234, 18, 18);
}
</style>

2.2 将class属性值绑定为对象

复制代码
<template>
  <div class="text" :class="{ box: isBox, border: isBorder }">
    <div :class="{ inner: isInner }">春夏</div>
    <div :class="classObject">秋冬</div>
    <div :class="classMeal">三餐四季~</div>
  </div>
</template>

<script setup>
import { ref, reactive, computed } from 'vue'
const isBox = ref(true)
const isBorder = ref(true)
const isInner = ref(true)
const isMeal = ref(true)
const classObject = reactive({ inner: true })
const classMeal = computed(() => ({
  meal: isMeal.value
}))
</script>

<style>
.text {
  text-align: center;
  line-height: 30px;
}
.box {
  width: 100%;
  background: linear-gradient(rgb(210, 13, 13), rgb(239, 250, 86));
}
.border {  border: 2px dotted black; }
.inner {
  margin-top: 2px;
  width: 100px; height: 30px;
  border: 2px double black;
}
.meal {
  width: 100px; height: 30px;
  border: 2px dashed rgb(120, 81, 227);
} 
</style>

2.3 将class属性值绑定为数组

用法演示

复制代码
<template>
  <div v-bind:class="[activeClass, borderClass]"></div>
  <div v-bind:class="[isActive ? activeClass : '', borderClass]"></div>
  <div v-bind:class="[{ active: isActive }, borderClass]"></div>
</template>
<script setup>
import { ref } from 'vue'
const isActive = ref(true)
const activeClass = ref('active')
const borderClass = ref('border')
</script>
<style>
.active {
  width: 100px;
  height: 10px;
  margin-bottom: 2px;
  background-color: rgb(59, 192, 241);
}
.border {
  border: 2px solid rgb(0, 0, 0);
}
</style>

效果

讲解

三、样式绑定style

3.1 将style属性值绑定为对象

复制代码
<template>
  <!-- 最外层必须只有一个根元素 -->
  <div>
    <!-- 绑定样式属性值 -->
    <div :style="{ backgroundColor: pink, width: width, height: height + 'px' }">
      <!-- 三元表达式 -->
      <div :style="{ backgroundColor: isBlue ? blue : 'black', width: '50px', height: '20px' }"></div>
      <!-- 绑定样式对象 -->
      <div :style="myDiv"></div>
    </div>
  </div>
</template>

<script setup>
import { ref, reactive } from 'vue'
const isBlue = ref(false)
const blue = ref('blue')
const pink = ref('pink')
const width = ref('100%')
const height = ref(40)
const myDiv = reactive({
  backgroundColor: 'red',
  width: '50px',
  height: '20px'
})
</script>

3.2 将style属性绑定为数组

复制代码
<template>
  <!-- 1. 纯数组:蓝→白渐变 -->
  <div class="box" :style="[activeGradient, borderClass]">纯数组样式</div>

  <!-- 2. 三元表达式:红→粉渐变 -->
   <!-- 这行代码就是:根据开关 isActive,决定要不要给盒子加上红色渐变,边框永远保留。 -->
  <div class="box" :style="[isActive ? redGradient : '', borderClass]">数组+三元表达式</div>

  <!-- 3. 数组+对象:绿→浅绿渐变 -->
  <div class="box" :style="[{ background: 'linear-gradient(to bottom, #52c41a, #b7eb8f)', height: '40px' }, borderClass]">数组+对象</div>
</template>

<script setup>
import { ref, reactive } from 'vue'

const isActive = ref(true)

// 蓝→白渐变
const activeGradient = reactive({
  height: '40px',
  background: 'linear-gradient(to bottom, rgb(59, 192, 241), rgb(200, 240, 255))'
})

// 红→粉渐变
const redGradient = reactive({
  height: '40px',
  background: 'linear-gradient(to bottom, rgb(255, 99, 71), rgb(255, 182, 193))'
})

const borderClass = reactive({
  border: '2px solid rgb(0, 0, 0)',
  margin: '10px 0'
})
</script>

<style>
.box {
  width: 200px;
  line-height: 40px;
  text-align: center;
}
</style>

四、知识点补充

4.1 class 和style的区别

Vue 中 classstyle 的核心区别

一、先一句话记住

  • class :绑定类名,样式写在 CSS 里

  • style :绑定行内样式,直接写 CSS 属性


二、详细对比

  1. class = 绑定类名
  • 控制:activeboxborder 这种类名

  • 样式写在 <style>

  • 适合:常用、复用、复杂样式

4.2 三元表达式

相关推荐
SEO_juper15 分钟前
新独立站冷启动收录全攻略:配置、推送、抓取配额优化完整手册
前端·谷歌·seo·跨境电商·外贸·geo·独立站
TinssonTai20 分钟前
这个 VS Code 插件让我的 AI Coding 又快又稳 - 旧瓶装新酒
前端·人工智能·程序员
体验家20 分钟前
体验家 XMPlus 网页端问卷 SDK 技术解析:用几行 JavaScript 实现精准场景触发与防打扰机制
开发语言·前端·javascript
VidDown26 分钟前
VidDown 工具站:视频分辨率技术
javascript·网络·编辑器·音视频·视频编解码·视频
Maimai1080835 分钟前
Web3 前端交易系统如何落地:从下单 UI 到 Operation 编码、签名与实时状态更新
前端·react.js·ui·架构·前端框架·web3
kidding72344 分钟前
高效备忘清单工具类小程序
前端·计算机网络·微信小程序·小程序
IMPYLH1 小时前
HTML 的 <abbr> 元素
前端·算法·html
小鹿软件办公1 小时前
倒计时开启:Chromium 宣布几周内将全面切断 MV2 扩展支持
开发语言·javascript·ublock origin
李白的天不白1 小时前
Tree-Shaking
前端
Csvn2 小时前
TypeScript:你以为安全的 `JSON.parse` 其实是颗雷 — 运行时类型安全实战
前端·javascript