初识Vue2(一):表单输入绑定(附Demo)
在线演示
下载地址
js引用
<!--这里可以自己下载下来引用,也可以使用外部动态链接引用-->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
基础用法
你可以用 v-model 指令在表单<input>、<textarea> 及<select>素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。
尽管有些神奇,但 v-model 本质上不过是语法糖。它负责监听用户的输入事件以更新数据,并对一些极端场景进行一些特殊处理。
v-model
会忽略所有表单元素的value
、checked
、selected
attribute 的初始值而总是将 Vue 实例的数据作为数据来源。你应该通过 JavaScript 在组件的
data
选项中声明初始值。
v-model 在内部为不同的输入元素使用不同的 property 并抛出不同的事件:
- text 和 textarea 元素使用
value
property 和input
事件; - checkbox 和 radio 使用
checked
property 和change
事件; - select 字段将
value
作为 prop 并将change
作为事件。
对于需要使用输入法 (如中文、日文、韩文等) 的语言,你会发现
v-model
不会在输入法组合文字过程中得到更新。如果你也想处理这个过程,请使用
input
事件。
点击事件和提示框
HTML
- <div id="example">
- <button v-on:click="say('我是按钮,你点击了我')">按钮点击</button>
- </div>
JS
- //一个vue的实例
- new Vue({
- el: '#example',
- data: {
- msg: 'Hello!'
- },
- //函数(用于弹框)
- methods: {
- say: function (i) {
- alert(i)
- }
- },
- });
计算机属性和侦听器
1、计算机属性
HTML
- <div id="example">
- <div>计算属性:{{toUp}}</div>
- <inputtype="text" v-model="ipt2">
- </div>
JS
- //一个vue的实例
- new Vue({
- el: '#example',
- data: {
- msg: 'Hello!',
- ipt: '我是计算机属性'
- },
- //计算属性
- computed: {
- toUp: function () {
- var that = this;
- var temp = that.ipt;
- return temp;
- }
- },
- });
这里我们声明了一个计算属性 toUp
你可以像绑定普通 property 一样在模板中绑定计算属性。
2、侦听器
虽然计算属性在大多数情况下更合适,但有时也需要一个自定义的侦听器。
这就是为什么 Vue 通过 watch 选项提供了一个更通用的方法,来响应数据的变化。
当需要在数据变化时执行异步或开销较大的操作时,这个方式是最有用的。
HTML
- <div id="example">
- <input type="text" v-model="ipt2">
- </div>
JS
- //一个vue的实例
- new Vue({
- el: '#example',
- data: {
- msg: 'Hello!',
- ipt2: '我是观察者(侦听器)'
- },
- //函数(用于弹框)
- methods: {
- say: function (i) {
- alert(i)
- }
- },
- //观察者
- watch: {
- // 如果 `ipt2` 发生改变,这个函数就会运行
- ipt2: function (newVal) {
- this.say(newVal)
- //console.log(this.ipt2);
- }
- }
- });
使用 watch
选项允许我们执行异步操作 (访问一个 API),限制我们执行该操作的频率,并在我们得到最终结果前,设置中间状态。这些都是计算属性无法做到的。
除了 watch
选项之外,您还可以使用命令式的 vm.$watch API。
文本
HTML
- <div id="example">
- <input v-model="message" placeholder="单行文本">输入的值: {{ message }}
- </div>
JS
- //一个vue的实例
- new Vue({
- el: '#example',
- message :"",
- });
多行文本
HTML
- <div id="example">
- <textarea v-model="message" placeholder="多行文本"></textarea><br />
- <span>输入的值:</span>
- <p style="white-space: pre-line;">{{ message }}</p>
- </div>
JS
- //一个vue的实例
- new Vue({
- el: '#example',
- message :"",
- });
自定义组件(简单):输出指定内容
在注册一个组件的时候,我们始终需要给它一个名字。比如在全局注册的时候我们已经看到了:
- Vue.component('my-component-name', { /* ... */ })
该组件名就是 Vue.component
的第一个参数。
你给予组件的名字可能依赖于你打算拿它来做什么。
当直接在 DOM 中使用一个组件 (而不是在字符串模板或单文件组件) 的时候,
我们强烈推荐遵循 W3C 规范中的自定义组件名 (字母全小写且必须包含一个连字符)。
这会帮助你避免和当前以及未来的 HTML 元素相冲突。
你可以在风格指南中查阅到关于组件名的其它建议。
HTML
- <div id="example">
- <simple></simple>
- </div>
JS
- // 注册一个全局自定义组件 simple
- Vue.component("simple", Vue.extend({
- template: '<div>我是一个div块哦</div>'
- }));
- //一个vue的实例
- new Vue({
- el: '#example'
- });
自定义组件(复杂):输出一个ul无序列表
HTML
- <div id="example">
- <do-list v-bind:data="list">
- </do-list>
- </div>
JS
- // 注册一个复杂全局自定义【组件】 do-list
- Vue.component("do-list", Vue.extend({
- //(父子传参)子组件要显式地用 props 选项声明它预期的数据:
- props: ['data'],
- template: `
- <ul>
- <li v-for="item in data">{{item.name}}</li>
- </ul>
- `
- }));
- //一个vue的实例
- new Vue({
- el: '#example',
- list: [
- { name: '西游记', author: '吴承恩' },
- { name: '红楼梦', author: '曹雪芹' },
- { name: '水浒传', author: '施耐庵' },
- { name: '三国演义', author: '罗贯中' }
- ],
- });
复选框
HTML
- <div id="example">
- <input type="checkbox" id="jack" value="Jack" v-model="checkedNames">
- <label for="jack">Jack</label>
- <input type="checkbox" id="john" value="John" v-model="checkedNames">
- <label for="john">John</label>
- <input type="checkbox" id="mike" value="Mike" v-model="checkedNames">
- <label for="mike">Mike</label>
- <span>选中的值: {{ checkedNames }}</span>
- </div>
JS
- //一个vue的实例
- new Vue({
- el: '#example',
- checkedNames: [], //多选
- });
单选按钮
HTML
- <div id="example">
- <input type="radio" id="one" value="One" v-model="picked">
- <label for="one">One</label>
- <input type="radio" id="two" value="Two" v-model="picked">
- <label for="two">Two</label>
- <span>选中的值: {{ picked }}</span>
- </div>
JS
- //一个vue的实例
- new Vue({
- el: '#example',
- picked: '', //单选
- });
下拉选择框
HTML
- <div id="example">
- <select v-model="selected">
- <option disabled value="">请选择</option>
- <option>Vue 1.x</option>
- <option>Vue 2.x</option>
- <option>Vue 3.x</option>
- </select>
- <span>选中的值: {{ selected }}</span>
- </div>
JS
- //一个vue的实例
- new Vue({
- el: '#example',
- selected: '' //单选框
- });
如果 v-model
表达式的初始值未能匹配任何选项,<select>
元素将被渲染为“未选中”状态。
在 iOS 中,这会使用户无法选择第一个选项。因为这样的情况下,iOS 不会触发 change 事件。
因此,更推荐像上面这样提供一个值为空的禁用选项。
![]() 欢迎关注订阅微信公众号【熊泽有话说】,更多好玩易学知识等你来取
作者:熊泽-学习中的苦与乐 公众号:熊泽有话说 出处:https://www.cnblogs.com/xiongze520/p/14764147.html 创作不易,任何人或团体、机构全部转载或者部分转载、摘录,请在文章明显位置注明作者和原文链接。 |
初识Vue2(一):表单输入绑定(附Demo)的更多相关文章
- 前端MVC Vue2学习总结(五)——表单输入绑定、组件
一.表单输入绑定 1.1.基础用法 你可以用 v-model 指令在表单控件元素上创建双向数据绑定.它会根据控件类型自动选取正确的方法来更新元素.尽管有些神奇,但 v-model 本质上不过是语法糖, ...
- Vue的指令系统、计算属性和表单输入绑定
指令系统 指令 (Directives) 是带有 v- 前缀的特殊特性.指令特性的值预期是单个 JavaScript 表达式 (v-for 是例外情况,稍后我们再讨论).指令的职责是,当表达式的值改变 ...
- Blazor和Vue对比学习(基础1.9):表单输入绑定和验证,VeeValidate和EditFrom
这是基础部分的最后一章,内容比较简单,算是为基础部分来个HappyEnding.我们分三个部分来学习: 表单输入绑定 Vue的表单验证:VeeValidate Blazor的表单验证:EditForm ...
- Vue表单输入绑定(文本框和复选框)
文本框 <!DOCTYPE html><html> <head> <meta charset="utf-8"> ...
- Vue.js教程--基础2(事件处理 表单输入绑定
事件处理 表单输入绑定 事件处理 监听v-on 监听 DOM 事件,并在触发时运行一些 JavaScript 代码. 可以在v-on:click=''加内联语句. 有时也需要在内联语句处理器中访问原始 ...
- Vue学习计划基础笔记(五) - 表单输入绑定、组件基础
表单输入绑定.组件基础 目标: 熟练掌握vue中表单的处理方式 对之前学习的内容简单回顾一下,并写一个实例,学以致用(最好脱离文档) vue中表单的处理方式 vue中表单的处理使用了v-model指令 ...
- VUE:事件处理和表单输入绑定
事件处理 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <titl ...
- vue样式绑定、事件监听、表单输入绑定、响应接口
1.样式绑定 操作元素的 class 列表和内联样式是数据绑定的一个常见需求.因为它们都是属性,所以我们可以用 v-bind 处理它们:只需要通过表达式计算出字符串结果即可.不过,字符串拼接麻烦且易错 ...
- Vue(10)表单输入绑定v-model
v-model v-model指定可以实现表单值与属性的双向绑定.即表单元素中更改了值会自动的更新属性中的值,属性中的值更新了会自动更新表单中的值 绑定的属性和事件 v-model在内部为不同的输入元 ...
随机推荐
- css行高
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="U ...
- find文本处理(locate)实例学习记录
find文本处理(locate)实例学习记录 (一)按文件名称查找 按照文件名称查找是 find 最常见的用法,需要注意的是,搜索的文件名必须完全匹配,才能找到对应的文件. 1. 查找当前目录下所有 ...
- Java并发编程之基础理论
内存模型 主内存.工作内存与Java堆.栈.方法区并不是同一个层次的内存划分 勉强对应起来 从定义来看,主内存对应Java堆中对象实例数据部分,工作内存对应虚拟机栈中部分区域 从更低层次来说,主内 ...
- 基于Hive进行数仓建设的资源元数据信息统计:Hive篇
在数据仓库建设中,元数据管理是非常重要的环节之一.根据Kimball的数据仓库理论,可以将元数据分为这三类: 技术元数据,如表的存储结构结构.文件的路径 业务元数据,如血缘关系.业务的归属 过程元数据 ...
- 【C/C++】面相对象开发之封装
封装继承多态是面向对象程序开发的基础概念.是实现面向对象的基本要素. 封装 程序开发,最核心价值,是数据. 程序其实是读取数据,操作数据,保存数据等一系列操作. 那么经过良好组织过的数据,将使编程事半 ...
- 1. HTML <fieldset> 标签
定义和用法 fieldset 元素可将表单内的相关元素分组. <fieldset> 标签将表单内容的一部分打包,生成一组相关表单的字段. 当一组表单元素放到 <fieldset> ...
- 认识Git并了解Git的基本知识
目录 认识Git 版本控制 版本控制的发展史 安装Git Git的核心概念 Git的使用原理 Git的工作流程 Git的基本流程 Git与SVN的区别 Git的基本使用 初始化Git 创建一个Git仓 ...
- math random模块
math --- 数学函数 该模块提供了对C标准定义的数学函数的访问,返回值除非有明确说明,否则所有返回值均为浮点数 math.ceil(x) 返回 x 的上限,即大于或者等于 x 的最小整数. 如果 ...
- RandomForestClassifier参数
[RandomForestClassifier] 参数 n_estimators : 随机森林中树的个数,即学习器的个数. max_features : 划分叶子节点,选择的最大特征数目 n_feat ...
- .Net之静态资源
介绍 静态文件都存储在Core Web根目录中.默认目录是<content_root>/wwwroot,但可通过 UseWebRoot方法更改访问目录.而content_root是指web ...