当前位置: 首页 > article >正文

vue2基础系列教程之v-model及面试高频问题

v-model是表单组件里面的核心知识点,这个指令给我们写表单业务带来了很大的方便。
请添加图片描述

  • 元素标签上的 v-model 指令用于双向绑定数据,它是一个语法糖,可以用于代替 v-bind:value@input

    • 例如:<input v-model="message" placeholder="edit me">
    • 相当于:<input :value="message" @input="message = $event.target.value">
  • 组件上的 v-model 指令默认会使用 value 属性与组件数据双向绑定,可以通过 model 选项来更改

一般使用

const inputTemplate = `
          <input :placeholder="message" v-bind:value="value" @input="updateValue" />`;
Vue.component("custom-input", {
  template: inputTemplate,
  props: ["value", "message"],
  methods: {
    updateValue(e) {
      this.$emit("input", e.target.value);
    },
  },
});

var app = new Vue({
  el: "#app",
  data() {
    return {
      message: "",
      username: "",
    };
  },
  methods: {
    onFocus() {
      this.message = "输入框被点击了";
    },
    onBlur() {
      this.message = "";
    },
  },
});
<div id="app">
  <h3>{{username}}</h3>
  <custom-input v-model="username" :placeholder="message" />
</div>

自定义组件绑定原生事件

## 自定义组件绑定原生事件

根据 vue 的设计理念,自定义组件上的属性和事件,会默认绑定到组件的根元素上,如果想要绑定到组件的原生事件上,需要使用 .native 修饰符。
也就是我们在组件内部不使用 props 进行显示的接受,这些属性和事件会默认的绑定到组件的根元素上。 @focus.native="onFocus" @blur.native="onBlur" class="custom-input" 这三个属性我在组件内部没有使用 props 进行接受,但是却可以正常的使用。

<div id="app">
  <h3>{{username}}</h3>
  <custom-input
    class="custom-input"
    v-model="username"
    :placeholder="message"
    @focus.native="onFocus"
    @blur.native="onBlur"
  />
</div>
const inputTemplate = `
          <input :placeholder="message" v-bind:value="value" @input="updateValue" />`;
Vue.component("custom-input", {
  template: inputTemplate,
  props: ["value", "message"],
  methods: {
    updateValue(e) {
      this.$emit("input", e.target.value);
    },
  },
});

var app = new Vue({
  el: "#app",
  data() {
    return {
      message: "请输入要显示的文字",
      username: "",
    };
  },
  methods: {
    onFocus() {
      this.message = "输入框被点击了";
    },
    onBlur() {
      this.message = "";
    },
  },
});

请添加图片描述

关于inheritAttrs

在 vue2.4 版本中,新增了 inheritAttrs 选项,默认情况下,组件上没有在 props 中声明的属性会被添加到组件的根元素上。
有时候,我们不希望这些属性添加到组件的根元素上,可以通过设置 inheritAttrs: false 来关闭这个功能。
同时,改造下inputTemplate

请添加图片描述
这时候,我们发现focusblur事件失效了,没有报错,就是没有触发。
这种情况,就需要我们手动来处理了,原因就是上面的原理

const inputTemplate = `
          <label>{{label}}
            <input  :placeholder="placeholder" :value="value" @input="updateValue" v-on="customListeners"/>
          </label>`;
Vue.component("custom-input", {
  inheritAttrs: false,
  template: inputTemplate,
  props: ["value", "placeholder", "label"],
  methods: {
    updateValue(e) {
      this.$emit("input", e.target.value);
    },
  },
  computed: {
    customListeners() {
      var vm = this;
      console.log("🚀 ~ customListeners ~ this.$listeners:", this.$listeners);
      return Object.assign({}, this.$listeners, {
        input: (e) => {
          vm.$emit("input", e.target.value);
        },
      });
    },
  },
});

var app = new Vue({
  el: "#app",
  data() {
    return {
      message: "请输入要显示的文字",
      username: "",
      label: "账号:",
    };
  },
  methods: {
    onFocus() {
      this.message = "输入框被点击了";
    },
    onBlur() {
      this.message = "";
    },
  },
});
<div id="app">
     <h3> {{username}}</h3>
      <custom-input class="custom-input" v-model="username" :placeholder="message" @focus="onFocus" @blur="onBlur" :label="label"/>
</div>

注意这里@focus="onFocus" @blur="onBlur",要去掉.native,不然也不生效
请添加图片描述


http://www.kler.cn/news/309538.html

相关文章:

  • CSP-J 算法基础 广度优先搜索BFS
  • 展锐平台手机camera 软硬件架构
  • 2024ICPC网络赛第一场
  • 【源代码+仿真+原理图+技术文档+演示视频+软件】基于物联网技术的宠物居家状况监测系统设计与实现
  • Kotlin 极简小抄 P1(变量与常量、基本数据类型、流程控制)
  • 【C++】一次rustdesk-server编译记录
  • 从数据仓库到数据中台再到数据飞轮:社交媒体的数据技术进化史
  • 计算机人工智能前沿进展-大语言模型方向-2024-09-12
  • LED灯、蜂鸣器、继电器的控制
  • 【店雷达全网图搜比价盘点】1688、淘宝、阿里国际、亚马逊、速卖通5大平台
  • 一次渲染十万条数据:前端技术优化(上)
  • Java 入门指南:JVM(Java虚拟机)垃圾回收机制 —— 新一代垃圾回收器 ZGC 收集器
  • 分布式中间件-redis相关概念介绍
  • B3636 文字工作
  • LabVIEW编程快速提升的关键技术
  • 【VScode】配置多账户连接远程服务器
  • PWN College 关于sql盲注
  • 【Hot100】LeetCode—72. 编辑距离
  • vue2制作高复用页面
  • 系统架构师考试学习笔记第五篇——架构设计补充知识(25)专业英语
  • Spring部分常见面试题
  • 关于Spring Cloud Gateway中 Filters的理解
  • 健身房预约小程序定制搭建,数字化运营管理
  • Python+Pytest框架,“api_key.py文件怎么编写“?
  • 【乐企-业务篇】生成发票左上角二维码
  • Linux和C语言(Day 12)
  • 华南医电科技集团受邀出席中马建交50周年高级别经贸合作交流活动
  • [Redis] Redis中的set和zset类型
  • 云轴科技ZStack 获鲲鹏应用创新大赛2024上海赛区决赛一等奖
  • vue3-print打印eletable某一行的数据