IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue.esm.js版本 引入DatePick时 会报错 -> 正文阅读

[JavaScript知识库]vue.esm.js版本 引入DatePick时 会报错

vue 使用es版本(vue.esm.js)引入element_ui DatePicker组件时 点击DatePicker组件 会报如下错误

为什么要使用vue.esm.js版本的vue呢

  • vue脚手架工具开发版默认加载的时运行时的版本(运行时的版本没有compiler编译,也就是不能写template(不是.vue中的template,.vue中的template 使用vue-loader,将.vue文件解析成render()函数后编译的),体积小,运行快。
  • 需要使用template
    //图片组件
     var ImgItem = {
       props: ["data"],
       render(createElement) {
         return createElement("div", [
           createElement(
             "h5",
             {
               style: {
                 textAlign: "center",
               },
             },
             "图片"
           ),
           createElement(
             "div",
             {
               style: {
                 //绑定样式
                 display: "flex",
                 flexWrap: "wrap",
                 justifyContent: "flex-start",
                 background: "#ddd",
                 padding: "0 5px",
                 width: "100%",
                 boxSizing: "border-box",
               },
             },
     
             [
               this.data.imgArr.map((item) => {
                 return createElement("img", {
                   attrs: {
                     src: item,
                   },
                   style: {
                     width: "50%",
                     margin: "10px 0px ",
                     padding: "0px 4px",
                     boxSizing: "border-box",
                   },
                 });
               }),
             ]
           ),
           createElement(
             "div",
             {
               style: {
                 width: "100%",
                 margin: "0 auto",
                 display: "flex",
                 flexWrap: "wrap",
               },
             },
             [
               this.data.content.map((item) => {
                 return createElement(
                   "span",
                   {
                     style: {
                       fontSize: "18px",
                       fontWeight: "700",
                       padding: "0px 4px",
                       boxSizing: "border-box",
                       display: "block",
                       width: "100%",
                       margin: "10px 0px ",
                     },
                   },
                   item
                 );
               }),
             ]
           ),
         ]);
       },
     };
     // 视频组件
     var VideoItem = {
       props: ["data"],
       render(createElement) {
         return createElement(
           "div",
           {
             style: {
               width: "100%",
               height: "510px",
               margin: "0 auto",
             },
           },
           [
             createElement(
               "h5",
               {
                 style: {
                   textAlign: "center",
                 },
               },
               "视频"
             ),
             createElement("video", {
               attrs: {
                 src: this.data.url,
                 controls: "controls",
                 autoplay: "autoplay",
               },
               style: {
                 width: "100%",
                 height: "92%",
                 margin: "0 auto",
               },
             }),
           ]
         );
       },
     };
     // 纯文本组件选项
     var TextItem = {
       props: ["data"],
       render(createElement) {
         return createElement("div", [
           createElement("p", "纯文本组件"),
           createElement("p", this.data.text),
         ]);
       },
     };
     // 函数组件化
     Vue.component("smart-item", {
       functional: true,
       render(createElement, context) {
         let data;
         function getComponent() {
           data = context.props.data;
           if (data.type === "img") return ImgItem;
           if (data.type === "video") return VideoItem;
           return TextItem;
         }
         return createElement(
           getComponent(),
           {
             props: {
               data: context.props.data,
             },
           },
           context.children
         );
       },
       props: {
         data: {
           type: Object,
           required: true,
         },
       },
     });
    

请添加图片描述

解决方法

配置webpackage文件

module.exports = {
  configureWebpack: {
    name: name,
    resolve: {
      alias: {
         vue: "vue/dist/vue.esm.js",
      }
    }
  },
};

将导入vue import Vue from "vue/dist/vue.esm.js"; 更改import Vue from 'vue'

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-10-08 20:32:10  更:2022-10-08 20:34:43 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 15:56:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码