iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何使用vue组件封装共用的组件
  • 254
分享到

如何使用vue组件封装共用的组件

2023-06-30 16:06:58 254人浏览 薄情痞子
摘要

这篇文章主要介绍了如何使用Vue组件封装共用的组件的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何使用vue组件封装共用的组件文章都会有所收获,下面我们一起来看看吧。这里提供两种vue封装共用组件的方法方法一

这篇文章主要介绍了如何使用Vue组件封装共用的组件的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何使用vue组件封装共用的组件文章都会有所收获,下面我们一起来看看吧。

    这里提供两种vue封装共用组件的方法

    方法一

    main.js

    import ListItem from './components/list.vue'//封装共用组件方法一Vue.component('ListItem',ListItem)

    方法二

    如何使用vue组件封装共用的组件

    新建vue文件的时候再建个相应的js文件。

    component.js

    import child from './component.vue' export default child.install = function (Vue) {  Vue.component(child.name,child)}

    main.js中

    import child from './components/component/component.js'//封装共用组件方法二Vue.use(child)

    通过上面的两种方法定义公共组件后都可以直接<child>和<component>这样调用组件了,无需在每个vue文件中important组件了。

    说说方法二吧根据官方文档提供的api

    如何使用vue组件封装共用的组件

    vue使用install定义安装全局组件需要install和use这两个api来配合才能完成。我更喜欢第一种但是今天看了公司的代码认识到了第二种方法,也发现了vue提供了不少提高生产效率的api往后会继续深入去学习这些api。

    同时也解决了一个困惑很长时间的问题,element ui中的message这个组件不需要vue.use安装直接就能用,因为element源码中直接将这个组件赋值到vue的prototype上了,其他的组件都只export 暴露出install方法所以其他组件需要vue.use安装

    vue封装公共组件调用方法

    需求:项目中所有的提示信息都是弹框样式的,并且显示两秒后自动消失

    vue页面

    <template>  <!-- 公用提示信息页面 -->  <el-dialog    title="提示"    :visible.sync="dialogVisible"    :show-close="false"    top="40vh"    width="30%"  >    <div class="content">      <span>{{ text }}</span>    </div>  </el-dialog></template>
    <script>export default {  data() {    return {      dialogVisible: true,      text: ""    };  }};</script>
    <style lang="less" scoped>.content {  font-size: 16px;  color: #333;  text-align: center;  span {    margin-left: 10px;  }}/deep/ .el-dialog__header {  padding: 0;  height: 50px;  line-height: 50px;  text-align: center;  font-weight: 600;  background-color: #08519c;}/deep/ .el-dialog__title {  color: #fff;}</style>

    js页面

    // 公共提示信息jsimport Vue from "vue";import Toast from "./dialogMessage.vue"; //引入组件// 返回一个“扩展实例构造器”let ToastConstructor = Vue.extend(Toast);let myToast = (text, duration) => {  let toastDom = new ToastConstructor({    el: document.createElement("div") //将toast组件挂载到新创建的div上  });  document.body.appendChild(toastDom.$el); //把toast组件的dom添加到body里  toastDom.text = text;  toastDom.duration = duration;  // 在指定 duration 之后让 toast消失  setTimeout(() => {    toastDom.dialogVisible = false;  }, toastDom.duration);  // 调用时  this.$toast("新内容", 1000);};export default myToast;

    在main.js中全局注册

    import toast from "./components/dialogMessage.js"; //引入toast函数  //给Vue对象添加$toast方法  Vue.prototype.$toast = toast;

    页面中使用,像使用message一样

     this.$toast("新内容", 1000);

    效果

    如何使用vue组件封装共用的组件

    关于“如何使用vue组件封装共用的组件”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“如何使用vue组件封装共用的组件”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

    --结束END--

    本文标题: 如何使用vue组件封装共用的组件

    本文链接: https://www.lsjlt.com/news/330302.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作