【Vue3】2-10 : 表单处理与双向数据绑定原理

本书目录:点击进入

一、表单处理

1.1、【双向绑定】实现方式一:v-model

[> 代码](#> 代码)

[> 效果](#> 效果)

[1.2、【双向绑定】实现方式二::value属性 + input事件](#1.2、【双向绑定】实现方式二::value属性 + input事件)

[> 代码](#> 代码)

[> 效果 (同上)](#> 效果 (同上))

二、实战

[2.1 【v-model 示例】输入框](#2.1 【v-model 示例】输入框)

[> 代码 + 效果 (见1.1)](#> 代码 + 效果 (见1.1))

[2.2 【v-model 示例】单选框](#2.2 【v-model 示例】单选框)

[> 代码](#> 代码)

[> 效果](#> 效果)

[2.3 【v-model 示例】复选框](#2.3 【v-model 示例】复选框)

[> 代码](#> 代码)

[> 效果](#> 效果)

[2.4 【v-model 示例】下拉菜单](#2.4 【v-model 示例】下拉菜单)

[> 代码](#> 代码)

[> 效果](#> 效果)


一、表单处理

  • 收集表单数据,发送给后端

  • 把后端的数据进行回显

  • v-model 指令 实现响应式数据的处理。原理相当于 :value属性 + input事件

  • v-model除了可以处理输入框以外,也可以用在单选框、复选框、以及下拉菜单中。

1.1、【双向绑定】实现方式一:v-model

> 代码

html 复制代码
<body>
  <div id="app">
     <input type="text" v-model="message">
  </div>
  <script>

    let vm = Vue.createApp({
      data(){
        return {
          message: 'hello world'
        }
      }
    }).mount('#app');

    setTimeout(()=>{
      vm.message = 'hi vue'
    }, 5000)

  </script>
</body>

> 效果

1.2、【双向绑定】实现方式二::value属性 + input事件

> 代码

html 复制代码
<body>
  <div id="app">
    <!--<input type="text" v-model="message">-->
    <input type="text" :value="message" @input="message = $event.target.value">
  </div>
  <script>

    let vm = Vue.createApp({
      data(){
        return {
          message: 'hello world'
        }
      }
    }).mount('#app');

    setTimeout(()=>{
      vm.message = 'hi vue'
    }, 5000)

  </script>
</body>
</html>

> 效果 (同上)

二、实战

2.1 【v-model 示例】输入框

> 代码 + 效果 (见1.1)

2.2 【v-model 示例】单选框

> 代码

html 复制代码
  <div id="app">
    <input type="radio" v-model="gender" value="女">女<br>
    <input type="radio" v-model="gender" value="男">男<br>
    {{ gender }} 

  </div>
  <script>

    let vm = Vue.createApp({
      data(){
        return {
          gender: '男'
        }
      }
    }).mount('#app');

  </script>

> 效果

2.3 【v-model 示例】复选框

> 代码

html 复制代码
  <div id="app">
    <input type="checkbox" v-model="fruits" value="苹果">苹果<br>
    <input type="checkbox" v-model="fruits" value="西瓜">西瓜<br>
    <input type="checkbox" v-model="fruits" value="哈密瓜">哈密瓜<br>
    {{ fruits }}

  </div>

  <script>
    let vm = Vue.createApp({
      data(){
        return {
          fruits: ['西瓜', '哈密瓜']
        }
      }
    }).mount('#app');
  </script>

> 效果

2.4 【v-model 示例】下拉菜单

> 代码

html 复制代码
  <div id="app">
    <select v-model="city">
      <option value="北京">北京</option>
      <option value="上海">上海</option>
      <option value="杭州">杭州</option>
    </select>
    {{ city }}
  </div>

  <script>
    let vm = Vue.createApp({
      data(){
        return {
          city: '杭州'
        }
      }
    }).mount('#app');
  </script>

> 效果

相关推荐
努力学习的小廉几秒前
我爱学算法之—— 递归回溯综合(二)
开发语言·算法
sheji52612 分钟前
JSP基于信息安全的读书网站79f9s--程序+源码+数据库+调试部署+开发环境
java·开发语言·数据库·算法
2301_763472462 分钟前
C++网络编程(Boost.Asio)
开发语言·c++·算法
毕设源码-邱学长3 分钟前
【开题答辩全过程】以 基于Java Web的电子商务网站的用户行为分析与个性化推荐系统为例,包含答辩的问题和答案
java·开发语言
程序员清洒9 分钟前
Flutter for OpenHarmony:Text — 文本显示与样式控制
开发语言·javascript·flutter
摇滚侠18 分钟前
Java项目教程《尚庭公寓》java项目从开发到部署,技术储备,MybatisPlus、MybatisX
java·开发语言
轩情吖30 分钟前
Qt的窗口
开发语言·c++·qt·窗口·工具栏·桌面级开发
€81130 分钟前
Java入门级教程24——Vert.x的学习
java·开发语言·学习·thymeleaf·数据库操作·vert.x的路由处理机制·datadex实战
hcnaisd240 分钟前
深入理解C++内存模型
开发语言·c++·算法
雨季66643 分钟前
Flutter 三端应用实战:OpenHarmony 简易“动态内边距调节器”交互模式深度解析
javascript·flutter·ui·交互·dart