专栏首页finleyMa补充上一篇 实现基于最新chrome的动态按需加载组件

补充上一篇 实现基于最新chrome的动态按需加载组件

先看 这里 有一个提案,建议引入import()函数,完成动态加载。

import(specifier)

上面代码中,import函数的参数specifier,指定所要加载的模块的位置。import命令能够接受什么参数,import()函数就能接受什么参数,两者区别主要是后者为动态加载。

import()返回一个 Promise 对象。下面是一个例子。

const main = document.querySelector('main');

import(`./section-modules/${someVariable}.js`)
  .then(module => {
    module.loadPageInto(main);
  })
  .catch(err => {
    main.textContent = err.message;
  });

import()函数可以用在任何地方,不仅仅是模块,非模块的脚本也可以使用。它是运行时执行,也就是说,什么时候运行到这一句,也会加载指定的模块。另外,import()函数与所加载的模块没有静态连接关系,这点也是与import语句不相同。

import()类似于 Node 的require方法,区别主要是前者是异步加载,后者是同步加载。

syntax-dynamic-import

这种方式chrome63后已经原生支持了,但是如果是不支持浏览器就需要babel了。 看这里 https://babeljs.io/docs/plugins/syntax-dynamic-import/

运用

  1. vue的router.js中
import Vue from 'vue'
import Router from 'vue-router'

Vue.use(Router)

function load(component) {
  // '@' is aliased to src/components
  return () => import(`@/pages/${component}/index.vue`)
}

export default new Router({
  routes: [
    {
      path: '/',
      name: 'HelloWorld',
      component: load('HelloPage')
    },
    {
      path: '/tree',
      name: 'TreePage',
      component: load('TreePage')
    }
  ]
})
  1. vue加载多components
// http://www.css88.com/doc/lodash/#_kebabcasestring
// UploadFile => upload-file
import { kebabCase } from 'lodash'

const load = (component) => {
  return () => import(`../components/${component}.vue`)
}

const commonComponents = [
  'BaseFormDialog',
  'Datepicker',
  'HeaderContent',
  'UploadFile',
  'FullScreenButton',
  'RouterTreeview',
  'RouterLinkBack',
  'ModalDialog',
  'vSelect'
]

commonComponents.forEach(component => {
  Vue.component(kebabCase(component), load(component));
})

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Angular 使用 RxJS 优化处理多个Http请求

    注意:上面的this.http.get... 处理HTTP最好放到单独的Service文件中,再注入到Component。这里为了演示没有这么做。

    mafeifan
  • Angular 正式环境禁止console显示

    开发人员在开发过程中有意无意的在代码中使用console.log查看变量内容进行调试。 在正式环境最好屏蔽掉这些信息。更好的习惯是console.log用完就...

    mafeifan
  • Angular 依赖注入 初认

    服务是什么概念?可以简单地认为它是一个功能模块,重要在于它是单例对象,并且可以注入到其他的地方使用。

    mafeifan
  • python 实现elk接口获取数据

    [root@ctum2A0703016 ~]# cat jiaoyihao.py #!/usr/bin/python2.7

    py3study
  • 接口管理这下总会了吧?

    基于 Spring Boot 的约定大于配置,根据 YAML 中配置的接口分组信息,直接生成对应所需 Docket Bean

    架构探险之道
  • Python爬虫七麦APP榜单

    week
  • 使用云函数实现语音识别案例

    语音识别,也被称为自动语音识别 Automatic Speech Recognition,(ASR),其目标是将人类的语音中的词汇内容转换为计算机可读的输入,例...

    worker
  • 如何用Junit5玩出参数化测试的新花样?

    这是之前一篇文章《用junit5编写一个类ZeroCode的测试框架》的续集。主要将在之前工作的基础上,围绕参数化测试展开。 框架主要设计点:

    Antony
  • SpringBoot 中使用自定义的 Servlet, Filter, Listener

    1. 使用 @ServletComponentScan 定义要扫描的包目录, Servlet, Filter, Listener 可以通过 @WebServle...

    北漂的我
  • mall整合SpringSecurity和JWT实现认证和授权(二)

    Swagger api地址:http://localhost:8080/swagger-ui.html

    macrozheng

扫码关注云+社区

领取腾讯云代金券