Vue03基础语法--Vue组件+样式绑定+修饰符+常用控件+自定义指令+自定义事件

我不是女神ヾ 2024-04-01 08:40 144阅读 0赞

14天阅读挑战赛
努力是为了不平庸~

目录

1.样式绑定

  1. 事件修饰符

  2. 按键修饰符

  3. 常用控件

    4.1 常用控件示例

    4.2 修饰符

  4. 自定义指令

钩子函数:

5.1 局部

5.2 全局

  1. vue组件(重点)

  2. 自定义事件

    7.1 子 -> 父

    7.2 父 -> 子


1.样式绑定

  • class绑定
    使用方式:v-bind:,expression的类型:字符串、数组、对象

  • style绑定
    v-bind:style=”expression”, expression的类型:字符串、数组、对象

示例:

  1. <--定义示例样式-->
  2. <style>
  3. .fontClass {
  4. font-size: 40px;
  5. }
  6. .colorClass {
  7. color: red;
  8. }
  9. </style>
  10. <!--使用-->
  11. <p>
  12. <span v-bind:class="fc">fafa</span>
  13. </p>
  14. <p>
  15. <!--简写-->
  16. <span :class="ac">fafa</span>
  17. </p>
  18. <p>
  19. <!--直接使用style样式单-->
  20. <span style="font-size: 40px; color:blue;">aaa</span>
  21. <br/>
  22. <!-- 使用vue,样式名称为驼峰风格 。花括号,多个属性逗号分隔-->
  23. <span :style="{fontSize:fontSize+'px',color: color}">bbb</span>
  24. <br/>
  25. <span :style="myStyle">test</span>
  26. </p>
  27. var vm = new Vue({
  28. el: "#app",
  29. data: {
  30. fc: 'fontClass',
  31. ac: ['fontClass', 'colorClass'],
  32. fontSize: 40,
  33. color: 'green',
  34. //样式对象,注意:样式名使用驼峰命名,如:fontSize
  35. myStyle: {
  36. fontSize: '50px',
  37. color:'red',
  38. fontWeight: 'bold'
  39. }
  40. }
  41. });

2. 事件修饰符

几个常用的事件修饰符:

  1. <!-- 提交事件不再重载页面 -->
  2. <form v-on:submit.prevent="onSubmit"></form>
  3. <!-- click 事件只能点击一次 -->
  4. <a v-on:click.once="doThis"></a>
  5. <!-- 阻止单击事件冒泡 -->
  6. <a v-on:click.stop="doThis"></a>
  7. <!-- 修饰符可以串联 -->
  8. <a v-on:click.stop.prevent="doThat"></a>
  9. <!-- 添加事件侦听器时使用事件捕获模式 -->
  10. <div v-on:click.capture="doThis">...</div>

示例:

  1. <div>接收消息:{
  2. {receverMsg}}</div>
  3. <p>
  4. <!--响应多次或一次点击事件-->
  5. <input type="text" v-model="sendMsg">
  6. <button @click="sender">发送(多次)</button>
  7. <button @click.once="sender">发送(一次)</button>
  8. </p>
  9. <p>
  10. <!-- 阻止表单提交 -->
  11. <form action="testAction.action" method="post" @submit.prevent="doSubmit()">
  12. <label>名称</label>
  13. <input type="text" name="name"/>
  14. <input type="submit" value="提交"/>
  15. </form>
  16. </p>
  17. var vm = new Vue({
  18. el: "#app",
  19. data: {
  20. receverMsg: null,
  21. sendMsg: null
  22. },
  23. methods: {
  24. sender: function() {
  25. this.receverMsg = this.sendMsg;
  26. },
  27. doSubmit: function() {
  28. alert('ok');
  29. }
  30. }
  31. });

3. 按键修饰符

Vue允许为v-on在监听键盘事件时添加按键修饰符。

示例:

  1. <!-- 只有在 keyCode 是 13 时调用 vm.submit() -->
  2. <input v-on:keyup.13="submit">
  3. <!-- 利用下面的写法有同样的效果 -->
  4. <input v-on:keyup.enter="submit">





















































按键别名 含义
.enter 回车确认键
.tab TAB键
.delete 捕获 “删除” 和 “退格” 键
.esc 键盘左上角的Esc键,取消键
.space 空格键
.up
.down
.left
.right
.ctrl ctrl键
.shift shift键

示例:响应enter键事件

  1. <input type="text" @keyup.13="doSubmit" v-model="name">
  2. var vm = new Vue({
  3. el: "#app",
  4. data: function() {
  5. return {
  6. name: 'hello vue'
  7. }
  8. },
  9. methods: {
  10. doSubmit: function() {
  11. alert("响应enter," + this.name);
  12. }
  13. }
  14. });

4. 常用控件

4.1 常用控件示例

通过实现一个类型注册的页面,熟悉常用的控件。文本框/密码框/文本域/单选/多选/下拉列表

  1. <div id="app">
  2. <div>
  3. <label>账号:</label>
  4. <input type="text" v-model="uname">
  5. </div>
  6. <div>
  7. <label>密码:</label>
  8. <input type="password" v-model="upwd">
  9. </div>
  10. <div>
  11. <label>年龄:</label>
  12. <input type="text" v-model="age" >
  13. </div>
  14. <div>
  15. <label>性别:</label>
  16. <input type="radio" v-model="sex" value="1">
  17. <input type="radio" v-model="sex" value="2">
  18. </div>
  19. <div>
  20. <label>爱好:</label>
  21. <div style="display: inline;" v-for="h in hobbies">
  22. <input type="checkbox" :value="h.id" v-model="hobby"/>{
  23. {h.name}}
  24. </div>
  25. </div>
  26. <div>
  27. <label>地区</label>
  28. <select v-model="selectedCity">
  29. <option value="">-- 请选择 --</option>
  30. <option v-for="c in city" :value="c.id">{
  31. {c.name}}</option>
  32. </select>
  33. </div>
  34. <div>
  35. <label>备注:</label>
  36. <textarea v-model="remark"></textarea>
  37. </div>
  38. <div>
  39. <input type="checkbox" v-model="flag">是否已阅读并同意协议
  40. </div>
  41. <div>
  42. <button @click="submit" :disabled="disabled">提交</button>
  43. </div>
  44. </div>
  45. var vm = new Vue({
  46. el: "#app",
  47. data: {
  48. uname: '',
  49. upwd:'',
  50. age:'',
  51. sex: 1,
  52. //用于通过v-for指令输出多选框列表
  53. hobbies:[
  54. {id: '1', name:'打游戏'},
  55. {id: '2', name:'编程'},
  56. {id: '3', name:'旅游'}
  57. ],
  58. /*
  59. * 用于通过v-model双向绑定,保存用户的选择。
  60. * 此处为多选,需要通过数组接收,否则无法
  61. * 正常接收复选框的值,且复选框的行为也不正常,
  62. * 可能出现要么全部被选择,要么全部被取消的情况
  63. */
  64. hobby:[],
  65. remark: null,
  66. //用于生成地区选择列表
  67. city:[
  68. {id:"1", name:"长沙"},
  69. {id:"1", name:"株洲"},
  70. {id:"1", name:"湘潭"}
  71. ],
  72. //用于保存用户选择的地区
  73. selectedCity: '',
  74. //是否同意协议,默认值为false
  75. agreed:false,
  76. //提交按钮是否禁用,默认为true
  77. disabled: true
  78. },
  79. //监控agreed属性,如果同意协议则将提交按钮
  80. //设置为可用,否则提交按钮为禁用状态
  81. watch: {
  82. agreed: function(val) {
  83. if(val) {
  84. this.disabled = false;
  85. }else{
  86. this.disabled = true;
  87. }
  88. }
  89. },
  90. methods: {
  91. submit: function() {
  92. let data = {
  93. uname: this.uname,
  94. upwd: this.upwd,
  95. age:this.age,
  96. sex: this.sex,
  97. hobby: this.hobby,
  98. city: this.selectedCity,
  99. remark: this.remark
  100. }
  101. console.log(data);
  102. }
  103. }
  104. });

不使用监视器的简单方式: 删除监听器,然后将提交按钮的做如下修改

  1. <button @click="submit" :disabled="!agreed">提交</button>

4.2 修饰符






















修饰符 作用
.lazy 默认情况下, v-model在input事件中同步输入框的值与数据,但你可以添加一个修饰符lazy,从而转变为在change事件中同步
.number 将用户的输入值转为 Number 类型
.trim 自动过滤用户输入的首尾空格

以.number为例,示例修饰符的使用,将输入的年龄属性转换为数值型

  1. <div>
  2. <label>年龄:</label>
  3. <input type="text" v-model.number="age" >
  4. </div>

5. 自定义指令

Vue除支持内置的v-model/v-show等指令,还允许自定义指令。 vue2中,代码的复用和抽象的主要形式是组件,但在有些情况下仍然需要对普通dom元素做底层操作,这种情况下需要自定义指令。根据自定义指令的作用范围,可分为:全局、局部两种

钩子函数:






























名称 作用
bind 只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置
inserted 被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)
update 所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新 (详细的钩子函数参数见下)
componentUpdated 指令所在组件的 VNode 及其子 VNode 全部更新后调用
unbind 只调用一次,指令与元素解绑时调用

指令钩子函数会被传入以下参数:

  • el:指令所绑定的元素,可以用来直接操作 DOM 。
  • binding:一个对象,包含以下属性:
    1) name:指令名,不包括 v- 前缀。
    2) value:指令的绑定值,例如:v-my-directive=”1 + 1” 中,绑定值为 2。
    3) oldValue:指令绑定的前一个值,仅在 update 和 componentUpdated 钩子中可用。无论值是否改变都可用。
    4) expression:字符串形式的指令表达式。例如 v-my-directive=”1 + 1” 中,表达式为 “1 + 1”。
    5) arg:传给指令的参数,可选。例如 v-my-directive:foo 中,参数为 “foo”。
    6) modifiers:一个包含修饰符的对象。例如:v-my-directive.foo.bar 中,修饰符对象为 { foo: true, bar: true }。
  • vnode:Vue 编译生成的虚拟节点。移步 VNode API 来了解更多详情。
  • oldVnode:上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用。

5.1 局部

通过自定义标签设置文字颜色

  1. <div id="app">
  2. <!--red绑定到data里面的变量-->
  3. <p v-color="red">我是自定义指令</p>
  4. </div>
  5. var vm = new Vue({
  6. el: '#app',
  7. data: {
  8. red:'red'
  9. },
  10. //自定义指令,局部
  11. directives:{
  12. color: {
  13. inserted: function(el,binding) {
  14. console.log(el,binding);
  15. el.style.color = binding.value;
  16. }
  17. }
  18. }
  19. });

5.2 全局

  1. <div id="app">
  2. <!--red绑定到data里面的变量-->
  3. <p v-color="red">我是自定义指令</p>
  4. </div>
  5. //自定义标签,全局
  6. Vue.directive('color', {
  7. inserted: function(el,binding) {
  8. console.log(el,binding);
  9. el.style.color = binding.value;
  10. }
  11. })
  12. var vm = new Vue({
  13. el: '#app',
  14. data: {
  15. red:'red'
  16. }
  17. });

6. vue组件(重点)

6.1 组件介绍

  • 组件(Component)是Vue最强大的功能之一,
  • 组件可以扩展HTML元素,封装可重用的代码
  • 组件系统让我们可以用独立可复用的小组件来构建大型应用,几乎任意类型的应用的界面都可以抽象为一个组件树
  • 组件可以分为全局组件和局部组件

组件命名规则:

  • 短横线命名,如: my-component,vue推荐使用这种方式的命名规则
  • 首字母大写命名规则,如:MyComponent

props:

  • props是父组件用来传递数据的一个自定义属性。
  • 父组件的数据需要通过props把数据传给子组件,子组件需要显式地用props选项声明 “prop”

6.2 局部组件

定义语法:new Vue({el:’#d1’,components:{组件名:{配置选项}}})

  1. <div id="app">
  2. <div>
  3. <!--title是用来传值的自定义属性,在自定义组件的props中定义 -->
  4. <button-counter title="测试"/>
  5. </div>
  6. </div>
  7. var vm = new Vue({
  8. el: '#app',
  9. data: {
  10. ts: new Date().getTime()
  11. },
  12. //局部自定义组件
  13. components: {
  14. //组件名: {配置项}
  15. 'button-counter': {
  16. //用来传值的自定义属性
  17. props:['title'],
  18. //模板,模板中写的html代码,在其中可以使用{
  19. {}},及指令等vue元素
  20. template: '<button @click="doClick">{
  21. {title}}:局部组件,点击计数器:{
  22. {count}}</button>',
  23. //注意:在自定义的组件中需要使用函数来定义data
  24. data: function() {
  25. return {
  26. count: 0
  27. }
  28. },
  29. //定义响应事件函数
  30. methods: {
  31. doClick: function() {
  32. //注意此处this的作用返回是自定义组件,而不是上面声明
  33. //的vue实例.
  34. this.count++;
  35. }
  36. }
  37. }
  38. }
  39. });

注:为什么在自定义组件中必须使用函数方式来什么data?

每个自定义组件使用函数方式来声明data,这样每个实例可以维护一份被返回对象的独立的拷贝,在定义自定义组件时,一定要注意这一点。

6.3 全局组件

将上面的局部组件修改为全局组件。
全局组件定义语法:Vue.component(组件名, 配置选项)

  1. <div id="app">
  2. <div>
  3. <button-counter title="测试"/>
  4. </div>
  5. </div>
  6. //全局组件
  7. Vue.component('button-counter', {
  8. //用来传值的自定义属性
  9. props:['title'],
  10. //模板,模板中写的html代码,在其中可以使用{
  11. {}},及指令等vue元素
  12. template: '<button @click="doClick">{
  13. {title}}: 全局组件,点击计数器:{
  14. {count}}</button>',
  15. //注意:在自定义的组件中需要使用函数来定义data
  16. data: function() {
  17. return {
  18. count: 0
  19. }
  20. },
  21. //定义响应事件函数
  22. methods: {
  23. doClick: function() {
  24. //注意此处this的作用返回是自定义组件,而不是上面声明
  25. //的vue实例.
  26. this.count++;
  27. }
  28. }
  29. });
  30. var vm = new Vue({
  31. el: '#app',
  32. data: {
  33. ts: new Date().getTime()
  34. }
  35. });

7. 自定义事件

Vue自定义事件是为组件间通信设计, vue中父组件通过prop传递数据给子组件,而想要将子组件的数据传递给父组件,则可以通过自定义事件的绑定

  • 父Vue实例->子Vue实例,通过prop传递数据
  • 子Vue实例->父Vue实例,通过事件传递数据

7.1 子 -> 父

触发事件:$emit(eventName, 参数…)
注意:事件名必须用短横线命名方式。

  1. <div id="app">
  2. <!--子组件到父组件-->
  3. <div>
  4. <button-counter v-on:click-test="clickTest"/>
  5. </div>
  6. </div>
  7. var vm = new Vue({
  8. el: '#app',
  9. data: {
  10. ts: new Date().getTime()
  11. },
  12. //对于自定义的button-counter组件, Vue实例为父组件
  13. //在父组件中定义一个test方法,子组件调用该方法
  14. methods: {
  15. clickTest: function(msg) {
  16. console.log("test: "+ msg);
  17. }
  18. },
  19. //局部自定义组件
  20. components: {
  21. //组件名: {配置项}
  22. 'button-counter': {
  23. //用来传值的自定义属性
  24. props:['title'],
  25. //模板,模板中写的html代码,在其中可以使用{
  26. {}},及指令等vue元素
  27. template: '<button @click="doClick">{
  28. {title}}:局部组件,计数:{
  29. {count}}</button>',
  30. //注意:在自定义的组件中需要使用函数来定义data
  31. data: function() {
  32. return {
  33. count: 0
  34. }
  35. },
  36. //定义响应事件函数
  37. methods: {
  38. doClick: function() {
  39. //注意此处this的作用返回是自定义组件,而不是上面声明的vue实例.
  40. //注意事件名使用短横线命名方式
  41. this.$emit("click-test","hello vue");
  42. }
  43. }
  44. }
  45. }
  46. });

7.2 父 -> 子

注意:props定义属性时采用的是驼峰命名法,而在html中使用时需要对应的变为短横线命名法!!

  1. <div id="app">
  2. <!--子组件到父组件-->
  3. <div>
  4. <!-- 注意此处将定义props时的驼峰命名法,变为了短横线命名法 !!! -->
  5. <button-counter title-desc="测试" />
  6. </div>
  7. </div>
  8. var vm = new Vue({
  9. el: '#app',
  10. data: {
  11. ts: new Date().getTime()
  12. },
  13. //对于自定义的button-counter组件, Vue实例为父组件
  14. //在父组件中定义一个test方法,子组件调用该方法
  15. methods: {
  16. clickTest: function(msg) {
  17. console.log("test: "+ msg);
  18. }
  19. },
  20. //局部自定义组件
  21. components: {
  22. //组件名: {配置项}
  23. 'button-counter': {
  24. //用来传值的自定义属性
  25. //注意此处使用驼峰命名法 !!!
  26. props:['titleDesc'],
  27. //模板,模板中写的html代码,在其中可以使用{
  28. {}},及指令等vue元素
  29. template: '<button @click="doClick">{
  30. {titleDesc}}:局部组件,计数:{
  31. {count}}</button>',
  32. //注意:在自定义的组件中需要使用函数来定义data
  33. data: function() {
  34. return {
  35. count: 0
  36. }
  37. },
  38. //定义响应事件函数
  39. methods: {
  40. doClick: function() {
  41. //注意此处this的作用返回是自定义组件,而不是上面声明的vue实例.
  42. //注意事件名使用短横线命名方式
  43. this.count ++;
  44. console.log(this.titleDesc);
  45. }
  46. }
  47. }
  48. }
  49. });

以上就是今天的分享,感谢大家的观赏!!!

发表评论

表情:
评论列表 (有 0 条评论,144人围观)

还没有评论,来说两句吧...

相关阅读