我的 github 地址 - vue3.0Study - 阶段学习成果都会建立分支。
新组件 - 新路由 Forms.vue ( 下面仅介绍如何创立, 不进行介绍 ) :
<template><div class="form"> <input v-model="message" placeholder="edit me"> <p>Message is: {{ message }}</p> </div></template> <script> export default { name: 'forms', // eslint-disable-next-line data: function () { return { d: '' // eslint-disable-next-line } } } </script>
新建路由 ( 在 router.js 中 ):
import Forms from './views/Forms.vue' export default new Router({ routes: [ { path: '/', .......}, { path: '/form', name: 'forms', component: Forms }, { path: '/about', ......} ] })
这样就建立新的路由,这块我建立了新的 git commit。
注意:组件名称尽量满足以下要求:1、勿采用 HTML 标签名;2、勿采用 vue 内部保留的名称如 slot ( 插槽 )、partial、component等。3、以字母开头。更加详细的组件命名内容请参见:https://cnodejs.org/topic/5816aabdcf18d0333412d323
文本表单
贴个代码,具体的使用方法不多介绍:
<template><div class="form"> <input v-model="message1" placeholder="单行文本"> <p>单行文本: {{ message1 }}</p> <span>多行文本:</span> <p>{{ message2 }}</p> <textarea v-model="message2" placeholder="多行文本"></textarea> </div></template> <script> export default { name: 'forms', // eslint-disable-next-line data: function () { return { message1: '', message2: '差值' // eslint-disable-next-line } } } </script>
需要注意的是:<textarea v-model="message2" placeholder="多行文本">{{ someProp }}</textarea>
中的红色部分无效。
选择框
<label for="cd" style="color:green">单选框:</label> <input type="checkbox" id="cd" v-model="checked1"> <label for="cd">{{ checked1 }}</label> <div> <label for="jack" style="color:green">复选集合:</label> <input type="checkbox" id="name1" value="章三" v-model="checkedNames"> <label for="name1">章三</label> <input type="checkbox" id="name2" value="里斯" v-model="checkedNames"> <label for="name2">里斯</label> <input type="checkbox" id="name3" value="王五" v-model="checkedNames"> <label for="name3">王五</label> <br> <span>所选的人有: {{ checkedNames }}</span> </div> <div> <label style="color:green">单选集合:</label> <input type="radio" id="nan" value="男" v-model="picked"> <label for="nan">男</label> <input type="radio" id="nv" value="女" v-model="picked"> <label for="nv">女</label> <br> <span>性别是: {{ picked }}</span> </div> <div> <label style="color:green">单选下拉框:</label> <select v-model="selected1"> <option disabled value="">请选择</option> <option>A</option> <option>B</option> <option>C</option> </select> <span>选择的是: {{ selected1 }}</span> </div> <div> <label style="color:green">多选下拉框:</label> <select v-model="selected2" multiple style="width: 50px;"> <option>A</option> <option>B</option> <option>C</option> </select> <span>选择的是: {{ selected2 }}</span> </div> export default { name: 'forms', // eslint-disable-next-line data: function () { return { checked1: null, checkedNames: [], picked: null, selected1: null, selected2: [], message1: null, message2: null // eslint-disable-next-line } } }
注意:尽管有的选择框,无须在 data 属性中也声明同样的属性,但别这么做,任何选择框的属性,都应该在 data 声明该属性。
对于多选框,也可以采用 v-for 来循环显示,读者可自行实验。
值绑定
上面介绍那些选择框,属性绑定的默认的值。对此先来看看下面这个例子:
<input type="checkbox" id="cd" v-model="checked1"> <label for="cd">{{ checked1 }}</label> <input type="checkbox" id="cd1" v-model="checked11" true-value="有效" false-value="无效" > <label for="cd1">{{ checked11 }}</label>
上面的例子,是系统默认的,选中之后 checked1 是 true。下面就是修改了选中之后,属性 checked11 对应的值,也就是【有效】。
再比如:<label style="color:green">绑定到a:<input type="radio" v-model="pick" v-bind:value="a"></label>
其中 v-bind:value="a" 意思:选中之后,data.pick = data.a 。在 js 中 data 必须要设置这两个属性,且 a 要有初始值。
可以绑定到对象:<label style="color:green">
绑定到对象:<input type="radio" v-model="pick1" v-bind:value="{a:1}"></label>
也可以:<label style="color:green">绑定到对象:<input type="radio" v-model="pick1" v-bind:value="obj"></label>
对于所有的上面介绍的表单,都可以采用这种值绑定,限于篇幅,不一一介绍。
最后还有 - 修饰符
.lazy .number .trim
.lazy 改变 input 和 textarea 输入框的更新模式。上面的两个输入框的例子,都是在敲键盘一边输入一边更新;加入这个之后,变成失去焦点才会更新。
.number 则是将强制输入转换为 Number 类型。
.trim 去掉输入的字符串空格 ( 注意:加入之后,不但首尾的空格会去掉,中间部分连续多个空格会替换为单个空格 )。
比如如下例子: <textarea v-model.trim="message2" placeholder="多行文本"></textarea>
关于组件内部的基础功能 ( 表单、指令、绑定、属性 ) 已经简单了解熟悉,深入的理解需要在运用过程中不断加深。后面的学习将进一步理解 MVC 框架的核心概念之一 【组件】。
总结
以上所述是小编给大家介绍的vue3.0 CLI - 2.4 - 新组件 Forms.vue 中学习表单 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]