Vue——关于自定义组件

现在基于vue的UI组件库有很多,比如iview,element-ui等。但有时候这些组件库满足不了我们的开发需求,这时候我们就需要自己写一个插件。

举第一个栗子

用vue-cli搭建好项目目录之后,在src/components下面新建一个文件夹放我们要写的插件,如图所示:

index.vue里写我们的组件,代码如下:

index.js里面写index.vue的install方法,并用Vue.component注册组件,代码如下:

接下来我们要在默认的main.js里将刚刚写的index.js文件导入,并通过Vue.use来使用它,代码如下:

大功告成,接下来在app.vue里直接使用就可以啦,可以看到页面已经显示相应的组件了,如图:

这时候我们还可以自定义click事件,并通过参数的方式传递给我们的插件,插件可以通过props属性获取到该事件,如图:

可以看到页面已经生效了:

Vue.component(id, [definition])用于注册或获取组件。

Vue.use(plugin)用于安装 Vue.js 插件。如果插件是一个对象,必须提供 install 方法。如果插件是一个函数,它会被作为 install 方法。install 方法调用时,会将 Vue 作为参数传入。当 install 方法被同一个插件多次调用,插件将只会被安装一次。

举第二个栗子

我们再建一个文件夹,如图:

我们要写一个组件,能够显示外部传进来的内容,并在3秒后自动消失,代码如下:

接下来我们要在index.js里使用构造器来创建它,如图:

依旧在默认的main.js里引用刚刚的js文件,并加入到Vue实例上,这样我们就可以直接通过this.$seconddemo()来调用了,代码如下:

import SecondDemo from './components/global/seconddemo/index'
Vue.prototype.$seconddemo = SecondDemo
复制代码

在app.vue里使用它,发现插件加载成功了,如图:

Vue.extend(options)是 Vue 的构造器,用于创建一个“子类”。

统一管理自定义组件

当组件数量很多时,我们可以通过提供一个统一的出口文件来管理这些自定义组件,首先在global文件夹下新建一个index.js文件,代码如图:

index.js文件帮我们把所有自定义的组件都通过Vue.component注册了,最后export一个包含install方法的对象给Vue.use()使用。

这时候我们不需要在main.js里逐个添加动态组件了,只需要导入统一的index.js文件,并用Vue.use它就ok了。

import global from './components/global/index.js'
Vue.use(global)
复制代码
### Vue3 自定义组件的创建与使用 #### 组件创建过程 在Vue3项目结构中的`src/components/`目录下可以创建新的`.vue`单文件组件。对于名为 `MyComponent.vue` 的简单自定义组件,其基本模板如下所示[^1]: ```html <template> <div class="my-component"> <!-- 这里放置HTML标记 --> Hello from My Component! </div> </template> <script setup> // 可选脚本部分用于逻辑处理 import { ref } from 'vue'; const message = ref('Hello!'); </script> <style scoped> /* 局部样式 */ .my-component { color: blue; } </style> ``` 此代码片段展示了如何构建一个基础的Vue3组件,其中包含了三个主要区域:模板(template),脚本(script)以及样式(style)[^1]。 #### 注册并使用组件 为了让其他地方能够识别这个新创建的组件,在父级组件内需注册它。有两种方式完成这一操作——全局注册或是局部注册。这里展示的是更灵活也更为推荐的做法即局部注册: ```javascript // 假设这是App.vue的内容 <script setup> import MyComponent from './components/MyComponent.vue'; </script> <template> <div id="app"> <h1>Welcome to App</h1> <!-- 使用子组件 --> <MyComponent /> </div> </template> ``` 上述例子中,通过`import`语句引入了之前定义好的`MyComponent`,随后便可以在模板区域内像标签一样调用它。 #### 处理非prop属性 当传递给组件一些未被声明为props或emits的attribute时(比如`class`, `style`, 或者`id`),这些会自动应用到根节点上除非特别指定了继承行为[^2]。这意味着如果希望某些特定类名应用于整个组件,则可以直接将其作为常规HTML属性附加上去而无需额外配置。 ```html <MyComponent class="custom-class" style="color:red;" /> ``` 这行代码将会把指定的颜色和类添加至渲染后的DOM元素之上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值