34 在Vue3中如何通过ref获取DOM元素

概述

通过ref获取DOM节点也是一种非常常见的用法。

最常见的地方就是表单提交的时候,我们经常会给表单绑定一个ref,在条件之前通过ref获取表单数据,并校验表单数据是否正确。

在本节课中,我们使用ref引用一个textarea文本域,同事实记录文本域中的段落数量,句子数量和单词数量。

本节课需要依赖一个第三方库,我们先安装:

bash 复制代码
yarn add countable

基本用法

我们创建src/components/Demo34.vue,代码如下:

html 复制代码
<script setup>
import * as Countable from 'countable'
import {onMounted, ref} from "vue";

const count = ref({})
const textAreaRef = ref(null)

onMounted(() => {
  Countable.on(textAreaRef.value, (value) => {
    count.value = value
  })
})
</script>
<template>
  <!--段落-->
  <textarea
      ref="textAreaRef"
      cols="50"
      rows="7"
  >
    </textarea>

  <!--段落计数-->
  <ul>
    <li>段落: {{ count.paragraphs }}</li>
    <li>句子: {{ count.sentences }}</li>
    <li>单词: {{ count.words }}</li>
  </ul>
</template>

接着,我们修改src/App.vue:

html 复制代码
<script setup>
import Demo from "./components/Demo34.vue"
</script>
<template>
  <h1>欢迎跟着Python私教一起学习Vue3入门课程</h1>
  <hr>
  <demo/>
</template>

然后,我们浏览器访问:http://localhost:5173/

完整代码

package.json

json 复制代码
{
  "name": "hello",
  "private": true,
  "version": "0.0.0",
  "type": "module",
  "scripts": {
    "dev": "vite",
    "build": "vite build",
    "preview": "vite preview"
  },
  "dependencies": {
    "countable": "^3.0.1",
    "vue": "^3.3.8"
  },
  "devDependencies": {
    "@vitejs/plugin-vue": "^4.5.0",
    "vite": "^5.0.0"
  }
}

vite.config.js

js 复制代码
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

export default defineConfig({
  plugins: [vue()],
})

index.html

html 复制代码
<!doctype html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <link rel="icon" type="image/svg+xml" href="/vite.svg" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Vite + Vue</title>
  </head>
  <body>
    <div id="app"></div>
    <script type="module" src="/src/main.js"></script>
  </body>
</html>

src/main.js

js 复制代码
import { createApp } from 'vue'
import App from './App.vue'

createApp(App).mount('#app')

src/App.vue

html 复制代码
<script setup>
import Demo from "./components/Demo34.vue"
</script>
<template>
  <h1>欢迎跟着Python私教一起学习Vue3入门课程</h1>
  <hr>
  <demo/>
</template>

src/components/Demo34.vue

html 复制代码
<script setup>
import * as Countable from 'countable'
import {onMounted, ref} from "vue";

const count = ref({})
const textAreaRef = ref(null)

onMounted(() => {
  Countable.on(textAreaRef.value, (value) => {
    count.value = value
  })
})
</script>
<template>
  <!--段落-->
  <textarea
      ref="textAreaRef"
      cols="50"
      rows="7"
  >
    </textarea>

  <!--段落计数-->
  <ul>
    <li>段落: {{ count.paragraphs }}</li>
    <li>句子: {{ count.sentences }}</li>
    <li>单词: {{ count.words }}</li>
  </ul>
</template>

启动方式

bash 复制代码
yarn
yarn dev

浏览器访问:http://localhost:5173/

相关推荐
米丘几秒前
了解 Javascript 模块化,更好地掌握 Vite 、Webpack、Rollup 等打包工具
前端
Heo2 分钟前
深入 React19 Diff 算法
前端·javascript·面试
滕青山3 分钟前
个人所得税计算器 在线工具核心JS实现
前端·javascript·vue.js
小怪点点4 分钟前
手写promise
前端·promise
国思RDIF框架13 分钟前
RDIFramework.NET Web 敏捷开发框架 V6.3 发布 (.NET8+、Framework 双引擎)
前端
颜酱13 分钟前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
Mintopia14 分钟前
如何在有限的时间里,活出几倍的人生
前端
炫饭第一名14 分钟前
速通Canvas指北🦮——变形、渐变与阴影篇
前端·javascript·程序员
Neptune115 分钟前
让我带你迅速吃透React组件通信:从入门到精通(上篇)
前端·javascript
小星哥哥16 分钟前
JavaScript 动态导入 (Dynamic Imports)
javascript