1. ref属性
- 被用来给元素或子组件注册引用信息(id的替代者)
 - 应用在html标签上获取的是真实DOM元素,应用在组件标签上是组件实例对象
 - 使用方式: 
  
- 打标识:
<h1 ref="xxx">.....</h1>或<School ref="xxx"></School> - 获取:
this.$refs.xxx 
 - 打标识:
 
<template>
  <div>
    <h1 v-text="msg" ref="title"></h1>
    <button ref="btn" @click="showDOM">点我输出上方的DOM元素</button>
    <School ref="sch" />
  </div>
</template>
<script>
//引入School组件
import School from "./components/School";
export default {
  name: "App",
  components: { School },
  data() {
    return {
      msg: "欢迎学习Vue!",
    };
  },
  methods: {
    showDOM() {
      console.log(this.$refs.title); //真实DOM元素
      console.log(this.$refs.btn); //真实DOM元素
      console.log(this.$refs.sch); //School组件的实例对象(vc)
    },
  },
};
</script>
 
2. props配置项
- 功能:让组件接收外部传过来的数据
 - 传递数据:
<Demo name="xxx"/> - 接收数据: 
  
- 第一种方式(只接收):
props:['name'] - 第二种方式(限制类型):
props:{name:String} - 第三种方式(限制类型、限制必要性、指定默认值):
 
 - 第一种方式(只接收):
 
props:{
	name:{
	type:String, //类型
	required:true, //必要性
	default:'张三' //默认值
	}
}
 
 
3. mixin(混入)
- 功能:可以把多个组件共用的配置提取成一个混入对象
 - 第一步定义混合:
 
{
    data(){....},
    methods:{....}
    ....
}
 
- 第二步使用混入: 
  
- 全局混入:
Vue.mixin(xxx) - 局部混入:
mixins:['xxx'] 
 - 全局混入:
 
mixin.js
export const hunru = {
  methods: {
    showName() {
      alert(this.name);
    },
  },
  mounted() {
    console.log("你好啊!");
  },
};
export const hunru2 = {
  data() {
    return {
      x: 100,
      y: 200,
    };
  },
};
 
main.js
//引入Vue
import Vue from 'vue'
//引入App
import App from './App.vue'
import {hunru} from './mixin'
//关闭Vue的生产提示
Vue.config.productionTip = false
//全局混入
Vue.mixin(hunru)
//创建vm
new Vue({
	el:'#app',
	render: h => h(App)
})
 
Student.vue
import {hunru2} from '../mixin'
export default {
  name: "Student",
  data() {
    return {
      name: "张三",
      sex: "男",
    };
  },
  //局部混入
  mixins:[hunru2]
};
 
4. 插件
- 功能:用于增强Vue
 - 本质:包含
install方法的一个对象,install的第一个参数是Vue,第二个以后的参数是插件使用者传递的数据。 - 定义插件:
 
对象.install = function (Vue, options) {
    // 1. 添加全局过滤器
    Vue.filter(....)
    // 2. 添加全局指令
    Vue.directive(....)
    // 3. 配置全局混入(合)
    Vue.mixin(....)
    // 4. 添加实例方法
    Vue.prototype.$myMethod = function () {...}
    Vue.prototype.$myProperty = xxxx
}
 
- 使用插件:
Vue.use()
plugins.js 
export default {
  install(Vue, x, y, z) {
    console.log(x, y, z);
    //全局过滤器
    Vue.filter("mySlice", function (value) {
      return value.slice(0, 4);
    });
    //定义全局指令
    Vue.directive("fbind", {
      //指令与元素成功绑定时(一上来)
      bind(element, binding) {
        element.value = binding.value;
      },
      //指令所在元素被插入页面时
      inserted(element, binding) {
        element.focus();
      },
      //指令所在的模板被重新解析时
      update(element, binding) {
        element.value = binding.value;
      },
    });
    //定义混入
    Vue.mixin({
      data() {
        return {
          x: 100,
          y: 200,
        };
      },
    });
    //给Vue原型上添加一个方法
    Vue.prototype.hello = () => {
      alert("你好啊");
    };
  },
};
 
main.js
//引入Vue
import Vue from "vue";
//引入App
import App from "./App.vue";
//引入插件
import plugins from "./plugins";
//关闭Vue的生产提示
Vue.config.productionTip = false;
//应用(使用)插件
Vue.use(plugins, 1, 2, 3);
//创建vm
new Vue({
  el: "#app",
  render: (h) => h(App),
});
 
5. scoped
- 作用:让样式在局部生效,防止冲突。
 - 写法:
<style scoped>...</style> 
6. nextTick
- 语法:
this.$nextTick(回调函数) - 作用:在下一次 DOM 更新结束后执行其指定的回调。
 - 什么时候用:当改变数据后,要基于更新后的新DOM进行某些操作时,要在
nextTick所指定的回调函数中执行。 
7. 插槽slot
- 作用:让父组件可以向子组件指定位置插入html结构,也是一种组件间通信的方式,适用于 
父组件 ===> 子组件 - 分类:默认插槽、具名插槽、作用域插槽
 
7.1 默认插槽
父组件中:
<Category>
   <div>html结构1</div>
</Category>
 
子组件中:
<template>
    <div>
       <!-- 定义插槽 -->
       <slot>插槽默认内容...</slot>
    </div>
</template>
 
7.2 具名插槽
父组件中:
<Category>
    <template slot="center">
      <div>html结构1</div>
    </template>
    <template v-slot:footer>
       <div>html结构2</div>
    </template>
</Category>
 
子组件中:
<template>
    <div>
       <!-- 定义插槽 -->
       <slot name="center">插槽默认内容...</slot>
       <slot name="footer">插槽默认内容...</slot>
    </div>
</template>
 
7.3 作用域插槽
- 数据在组件的自身,但根据数据生成的结构需要组件的使用者来决定。
 
父组件中:
<Category>
	<template scope="scopeData">
		<!-- 生成的是ul列表 -->
		<ul>
			<li v-for="g in scopeData.games" :key="g">{{g}}</li>
		</ul>
	</template>
</Category>
<Category>
	<template slot-scope="scopeData">
		<!-- 生成的是h4标题 -->
		<h4 v-for="g in scopeData.games" :key="g">{{g}}</h4>
	</template>
</Category>
 
子组件中:
<template>
    <div>
        <slot :games="games"></slot>
    </div>
</template>
<script>
    export default {
        name:'Category',
        props:['title'],
        //数据在子组件自身
        data() {
            return {
                games:['英雄联盟','炉石传说','杀戮尖塔','尼尔机械纪元']
            }
        },
    }
</script>










