Vue基础(31)_插件(plugins)、scoped样式

功能:用于增强Vue
本质 :包含install方法的一个对象,install的第一个参数Vue构造函数 ,第二个及以后的参数 是插件使用者传递的数据

定义插件:

javascript 复制代码
对象.install = function (Vue, option1, option2, option3...) {
    // 1. 添加全局过滤器。
    Vue.filter(....)

    // 2. 添加全局指令。
    Vue.directive(....)

    // 3. 配置全局混入(或者叫混合)。
    Vue.mixin(....)

    // 4. 添加实例属性或实例方法(vm和vc都可以调用)。
    Vue.prototype.$myMethod = function () {...}
    Vue.prototype.$myProperty = xxxx
}

暴露插件:

使用插件:Vue.use()

注意:

1、main.js中不要直接定义插件。

2、文件名建议命名为plugins【插件】。

3、插件中的install方法是Vue帮我们调用的,只有使用了插件,Vue才会帮我们调用install方法。

4、main.js中创建vm之前,要先使用插件【Vue.use()】。

scoped样式

脚手架当中编写样式的技巧。当多个组件的样式有冲突 时,以最后引入的组件的样式最终样式

作用

让样式在局部生效【样式仅对当前组件生效】,防止因App组件中通过import汇总组件时,同名样式冲突【比如不同组件中有相同类名等】。

写法

html 复制代码
<style scoped>

案例:

plugins.js

javascript 复制代码
export default {
    // 传入的第一参数是Vue构造函数,第二个及以后的参数,是插件使用者传递的数据。
    install(Vue, x, y, z) {
        console.log("你好啊!!!");
        console.log(Vue)
        console.log(Vue, x, y, z)

        // 全局过滤器
        Vue.filter('mySlice', function (value) {
            return value.slice(0, 4)
        })

        // 全局自定义指令
        Vue.directive('fbind', {
            // 指令和元素成功绑定时(一上来开始绑定)
            bind(element, binding) {
                element.value = binding.value
            },
            // 指令所在的模板被重新解析时
            update(element, binding) {
                element.value = binding.value
            }
        })

        // 定义全局混入
        Vue.mixin({
            data() {
                return {
                    x: 100,
                    y: 200
                }
            }
        })

        // 给Vue原型上添加一个属性和方法(vm和vc就能用了)
        Vue.prototype.a = 888
        Vue.prototype.hello = () => {
            alert("你好啊!!!")
        }
    }
}

main.js

javascript 复制代码
// 引入Vue
import Vue from "vue";
// 引入App
import App from "./App.vue";
// 关闭生产提示
Vue.config.productionTip = false;

// 引入插件
import plugins from "./plugins";

// 应用(使用)插件【多次调用同一插件时,只生效一次】
Vue.use(plugins,1,2,3);

// 创建vm
new Vue({
    el: '#app',
    render: h => h(App)
})

SchoolList.vue

html 复制代码
<template>
  <div>
    <h2 class="tip">学校名称:{{ name | mySlice}}</h2>
    <h2>学校地址:{{ address }}</h2>
    <h2>a的值是:{{ a }}</h2>
    <button @click="test">点我测试hello方法</button>
  </div>
</template>

<script>

export default {
  name: "SchoolList",
  data() {
    return {
      name: "南昌大学12345",
      address: "南昌市红谷滩新区",
    }
  },
  methods:{
    test(){
      this.hello()
    }
  }
};
</script>

<style>
.tip {
  background-color: darkorange;
}
</style>

StudentList.vue

html 复制代码
<template>
  <div>
    <h2 class="tip">学生姓名:{{ name }}</h2>
    <h2>学生性别:{{ sex }}</h2>
    <input type="text" v-fbind:value="name">
  </div>
</template>

<script>
export default {
  name: "StudentList",
  data() {
    return {
      name: "张三",
      sex: "男",
      age:18
    };
  }
};
</script>

<style>
.tip {
  background-color: darkcyan;
}
</style>

App.vue

html 复制代码
<template>
    <div>
        <SchoolList />
        <hr>
        <StudentList />
    </div>
</template>

<script>
import SchoolList from './components/SchoolList.vue';
import StudentList from './components/StudentList.vue';
export default {
    name:'App',
    components:{SchoolList,StudentList},
}
</script>

<style>
</style>

所有组件中,x、y值分别为:100、200。

相关推荐
M ? A2 小时前
Vue3+TS实战避坑指南
前端·vue.js·经验分享
Mintopia2 小时前
你以为是技术问题,其实是流程问题:工程效率的真相
前端
Mintopia2 小时前
一套能落地的"防 Bug"习惯:不用加班也能少出错
前端
亿元程序员2 小时前
箭头游戏那么火,搞个3D的可以吗?我:这不是3年前的游戏了吗?
前端
IT_陈寒2 小时前
SpringBoot里的这个坑差点让我加班到天亮
前端·人工智能·后端
巫山老妖2 小时前
大模型工程三驾马车:Prompt Engineering、Context Engineering 与 Harness Engineering 深度解析
前端
Cobyte2 小时前
4.响应式系统基础:从发布订阅模式的角度理解 Vue3 的数据响应式原理
前端·javascript·vue.js
晓得迷路了2 小时前
栗子前端技术周刊第 124 期 - ESLint v10.2.0、React Native 0.85、Node.js 25.9.0...
前端·javascript·eslint
半个俗人3 小时前
fiddler的基础使用
前端·测试工具·fiddler