1、vue指令-v-model修饰符

语法:

v-model.修饰符="vue数据变量"

.number   以parseFloat转成数字类型.trim     去除首尾空白字符.lazy     在失去焦点时触发更改而非inupt时

2、计算属性

计算属性有缓存,进步渲染性能。

如果在页面上须要用到 对现有的数据进行加工失去新数据,则时要应用计算属性。

写法:

computed: {    "属性名": {        set(值){                    },        get() {            return "值"        }    }}

3、vue监听器

能够监听数据(data/computed等)的值的扭转。数据的值有类型:根本数据类型,援用数据类型

深度监听

watch: {    "要监听的属性名": {        immediate: true, // 立刻执行        deep: true, // 深度监听简单类型内变动        handler (newVal, oldVal) {                    }    }}

4、scoped实现组件的公有款式

<stype scoped>  h2 {} // 款式只会在以后组件内失效</style>

5、父传子

父组件

<template>  <div>    <child :users="user"></child> <!-- 子组件绑定users变量-->  </div></template> <script>import { child } from "./child";export default {  components: { child },  data() {    return {      user: '张三'    };  }};</script>

子组件

<template>  <div>{{ users }}</div></template> <script>export default {  props: ["users"] //接管user值};</script>

6、子传父

子组件

<template>  <div>    <button @click="datas"></button>  </div></template> <script>export default {  methods: {    datas() {      this.$emit("info", value); //$emit 的第一个参数是父组件自定义事件的办法名,后边的 “value” 是子组件要给父组件传递的数据     }  }};</script>

父组件

<template>  <div>    <child @info="getInfo"></child>  </div></template> <script>import { child } from "./child";export default {  components: { child },  methods: {    getInfo(value) {      // value 就是子组件传递过去的数据    }  }};</script>

7、组件进阶 - props校验

props: {    // 根底的类型查看 (`null` 和 `undefined` 会通过任何类型验证)    propA: Number,    // 多个可能的类型    propB: [String, Number],    // 必填的字符串    propC: {      type: String,      required: true    },    // 带有默认值的数字    propD: {      type: Number,      default: 100    },    // 带有默认值的对象    propE: {      type: Object,      // 对象或数组默认值必须从一个工厂函数获取      default: function () {        return { message: 'hello' }      }    },    // 自定义验证函数    propF: {      validator: function (value) {        // 这个值必须匹配下列字符串中的一个        return ['success', 'warning', 'danger'].indexOf(value) !== -1      }    }  }

8、组件进阶 - 动静组件

<component :is="comName"></component> //comName是变量,值为须要切换的几个组件名

9、组件进阶 - keep-alive组件

用keep-alive内置的vue组件, 让动静组件缓存而不是销毁

<keep-alive>    <!-- vue内置的组件component, 能够动态显示组件 -->    <component :is="comName"></component></keep-alive>

组件进阶-keep-alive组件-指定缓存

语法

include="组件名1,组件名2..."
:include="['组件名1', '组件名2']"

<keep-alive include="name1,name2">    <!-- vue内置的组件component, 能够动态显示组件 -->    <component :is="comName"></component></keep-alive>

10、组件进阶 - 具名插槽

格局

定义:<slot name="xxx">应用:<template #xxx></template>;<template v-slot:xxx></template>

11、自定义指令 - 根本应用

{  data(){},  methods: {},  directives: {    focus: { // 自定义指令名        inserted(el){ // 固定配置项 - 当指令插入到标签主动触发此函数            el.focus()        }    },  },}

12、自定义指令 - 传值和更新

指标: 应用自定义指令, 传入一个值

需要: 定义color指令-传入一个色彩, 给标签设置文字色彩

main.js定义处批改一下

directives: {  "color":{    inserted(el, binding){ // 插入时触发此函数      el.style.color = binding.value;    },    update(el, binding){ // 更新绑定的变量时触发此函数=》手动更新      el.style.color = binding.value;    }  }}

Direct.vue处更改一下

<p v-color="theColor" @click="changeColor">应用v-color指令管制色彩, 点击变蓝</p><script>  data() {    return {      theColor: "red",    };  },  methods: {    changeColor() {      this.theColor = 'blue';    },  },</script>

总结: v-xxx, 自定义指令, 获取原生DOM, 自定义操作

13、axios申请

 async loadData(){     const res= await axios.get("http://.......")    // console.log(data); }, created(){    this.loadData() }