热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【ElementUI通用后台管理系统】(一)项目搭建(elementuiapi)

本文主要介绍关于npm,前端,node.js的知识点,对【ElementUI通用后台管理系统】(一)项目搭建和elementuiapi有兴趣的朋友可以看下由【小张快跑。】投稿的技术文章,希望该技

本文主要介绍关于npm,前端,node.js的知识点,对【Element UI通用后台管理系统】(一)项目搭建和element ui api有兴趣的朋友可以看下由【小张快跑。】投稿的技术文章,希望该技术和经验能帮到你解决你所遇的项目开发实战——Vue相关技术问题。

element ui api

一、使用Yarn作为项目的包管理工具 1、Yarn是什么?

“Yarn是由Facebook、Google、Exponent和Tilde联合推出了一个新的JS包管理工具,正如官方文档中写的,Yarn是为了弥补npm的一些缺陷而出现的。”这句话让我想起了使用npm时的坑:

npm install的时候非常慢,特别是新的项目拉下来要等半天,删除node_modules,重新install的时候依旧如此。同一个项目,安装的时候 无法保持一致性。由于package.json文件中版本号的特点,下面三个版本号在安装的时候代表的含义不同。

 "5.0.3"     表示:安装指定的5.0.3版本

"~5.0.3"    表示:安装5.0.x中最新的版本

"^5.0.3"     表示:安装5.x.x中最新的版本

这就显得很麻烦了,常常会出现同一个项目,有的同事时OK的 ,有的同事会由于安装的版本不一致出现bug。

安装的时候,包会在同一时间下载和安装,中途某个时候,一个包抛出了一个错误,但是npm会继续下载和安装包。因为npm会把所有的日志输出到终端,有关错误包的错误信息就会在一大堆npm打印的警告中丢失掉,并且你甚至永远 不会注意到实际发生的错误。 2、Yarn的优点? 速度快。速度快主要来自以下两个方面:   并行安装:无论npm还是Yarn在执行包的安装时,都会执行一系列任务。npm是按照队列执行每个package,也就是说必须要等到当前package安装完成后,才能继续后续的安装。而Yarn是同步执行所有的任务,提高了性能 离线模式:如果之前已经安装过一个软件包,用Yarn再次安装时,直接从缓存中获取,就不用像npm那样再从网络下载了。 安装版本统一:为了防止拉取到不同的版本,Yarn有一个锁定文件(lock file)记录了被确切安装上的模块的版本号。每次只要新增一个模块,Yarn就会创建(或更新)yarn lock这个文件。这么做就保证了,每一次拉取同一个项目依赖时,使用的都是一样的模块版本。npm其实也有很多办法实现处处使用相同版本的packages,但需要开发这执行npm shrinkwrap命令。这个命令将会生成一个锁定文,在执行npm install的时候,该锁定文件会先被读取,和Yarn读取yarn.lock两者的不同之处在于,Yarn默认会生成这样的锁定文件,而npm要通过shrinkwrap命令生成npm-shrinkwrap.json文件,只有这个文件存在的时候,packages版本信息才会被记录和更新。 更简洁的输出:npm的输出信息比较冗长。在执行npm install的时,命令行里会不断地打印出所有被安装上地依赖。相比之,Yarn简洁太多:默认情况下,结合了emoji直观且直接地打印出必要信息,也提供了一些命令供开发者查询额外的安装信息。**多注册来源处理:**所有的依赖包,不管他被不同的库间接关联引用多少次,安装这个包时,只会从一个注册来源去安装,要么是npm要么是bower,防止出现混乱不一致。 更好的语义化:yarn改变了一些npm命令的名称,比如yarn add/remove,感觉上比npm原本的install/uninstall要更清晰。 3、Yarn和npm命令对比 npm yarnnpm unstallyarnnpm install react --save

yarn add react

npm uninstall react --save

yarn remove react

npm install react --save-devyarn add react --devnpm update --saveyarn upgrade  二、搭建Vue-cli4脚手架 1、安装node.js

        进入node官网下载node(这里是node中文网,国际网址有时候非常卡)

Node.js 中文网Node.js 是一个基于 Chrome V8 引擎的 Javascript 运行环境。Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效。Node.js 的包管理器 npm,是全球最大的开源库生态系统。

http://nodejs.cn/

 

         可以直接安装,安装完毕后,可以在我们的cmd窗口,输入node -v查看node版本,如果能看到,说明安装成功。

        当node环境安装完成后,npm环境是自动安装好的,也可以在cmd命令输入npm -v,查看是否安装成功。

2、安装cnpm(npm的中国镜像)

        1、说明:npm(node package manager)是nodejs的包管理工具,用于node插件管理(包括安装、卸载、管理依赖等)。

        2、使用npm安装插件:命令提示行执行npm install

        3、选装cnpm,因为npm安装插件是从国外服务器下载,受网络影响大,可能出现异常。

cnpm切换淘宝镜像: npm install -g cnpm --registry=https://registry.npmmirror.com
例如:使用cnpm安装模块:cnpm install(下载package.json的依赖)
 3、安装Yarn

安装Yarn命令:npm install -g yarn

4、安装vue-cli脚手架构建工具

        Vue-cli提供一个官方命令行工具,可用于快速搭建大型单页应用。

安装Vue-cli命令:cnpm install -g @vue/cli  ||  yarn global add vue-cli

测试Vue脚手架是否安装成功:vue -V

5、创建项目

        这里如果有需求的同学,可以翻看我前面的文章。

Vue(四)Vue脚手架——手把手教你安装和使用_小张快跑。的博客-CSDN博客_前端vue脚手架安装Vue脚手架的安装与配置,脚手架的文件结构、我的第一个脚手架项目

https://blog.csdn.net/io_123io_123/article/details/122610993

 6、引入Element ui

        之所以使用Element ui,是因为它是Vue所支持的ui组件库,它可以在我们开发过程中,快速生成我们需要的ui样式,并且,它的组件能够做到开箱即用,bug少,样式比较美观。

        1、引入Element ui的两种方式

        CDN

        目前可以通过 unpkg.com/element-ui 获取到最新版本的资源,在页面上引入 js 和 css 文件即可开始使用。


  

  

  

        脚手架中的引入

全局引入

(1)下载全局依赖:npm i element-ui -S  ||  yarn add element-ui -S

(2) 在main.js中写入以下内容:

import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import App from './App.vue';

Vue.use(ElementUI);

new Vue({
  el: '#app',
  render: h => h(App)
});

 (3)在页面中引入element-ui组件

 
   
    按钮
   

         由于全局引入后,会导致我们的项目在打包时,将所有的Elementui组件进行打包,包括没有用到的组件,因此不推荐使用这种方式。

按需引入 

借助 babel-plugin-component,我们可以只引入需要的组件,以达到减小项目体积的目的。(也可以选择不安装这个插件)

(1)安装 babel-plugin-component:npm install babel-plugin-component -D

 (2)需要修改bable.config.js中的配置

{
  "presets": [["es2015", { "modules": false }]],
/***添加下面代码****/
  "plugins": [
    [
      "component",
      {
        "libraryName": "element-ui",
        "styleLibraryName": "theme-chalk"
      }
    ]
  ]
/***到此结束*****/
}

(3)如果你只希望引入部分组件,比如 Button 和 Select,那么需要在 main.js 中写入以下内容:

import Vue from 'vue';
import { Button, Select } from 'element-ui';
import App from './App.vue';

Vue.component(Button.name, Button);
Vue.component(Select.name, Select);
/* 或写为
 * Vue.use(Button)
 * Vue.use(Select)
 */

new Vue({
  el: '#app',
  render: h => h(App)
});

 上述操作之后,我们就能够在我们的项目中使用Element ui框架进行开发了。这里推荐使用按需引入,因为全局引入会将Element ui的所有依赖全部引入,大大影响我们的项目运行速度。

本文《【Element UI通用后台管理系统】(一)项目搭建》版权归小张快跑。所有,引用【Element UI通用后台管理系统】(一)项目搭建需遵循CC 4.0 BY-SA版权协议。


推荐阅读
  • React 小白初入门
    推荐学习:React官方文档:https:react.docschina.orgReact菜鸟教程:https:www.runoob.c ... [详细]
  • Hello.js 是一个用于连接OAuth2服务的JavascriptRESTFULAPI库,如Go ... [详细]
  • Vue基础一、什么是Vue1.1概念Vue(读音vjuː,类似于view)是一套用于构建用户界面的渐进式JavaScript框架,与其它大型框架不 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • 本文介绍了如何使用Express App提供静态文件,同时提到了一些不需要使用的文件,如package.json和/.ssh/known_hosts,并解释了为什么app.get('*')无法捕获所有请求以及为什么app.use(express.static(__dirname))可能会提供不需要的文件。 ... [详细]
  • 本文介绍了腾讯最近开源的BERT推理模型TurboTransformers,该模型在推理速度上比PyTorch快1~4倍。TurboTransformers采用了分层设计的思想,通过简化问题和加速开发,实现了快速推理能力。同时,文章还探讨了PyTorch在中间层延迟和深度神经网络中存在的问题,并提出了合并计算的解决方案。 ... [详细]
  • 本文介绍了RxJava在Android开发中的广泛应用以及其在事件总线(Event Bus)实现中的使用方法。RxJava是一种基于观察者模式的异步java库,可以提高开发效率、降低维护成本。通过RxJava,开发者可以实现事件的异步处理和链式操作。对于已经具备RxJava基础的开发者来说,本文将详细介绍如何利用RxJava实现事件总线,并提供了使用建议。 ... [详细]
  • 从零基础到精通的前台学习路线
    随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
  • 恶意软件分析的最佳编程语言及其应用
    本文介绍了学习恶意软件分析和逆向工程领域时最适合的编程语言,并重点讨论了Python的优点。Python是一种解释型、多用途的语言,具有可读性高、可快速开发、易于学习的特点。作者分享了在本地恶意软件分析中使用Python的经验,包括快速复制恶意软件组件以更好地理解其工作。此外,作者还提到了Python的跨平台优势,使得在不同操作系统上运行代码变得更加方便。 ... [详细]
  • 本文介绍了H5游戏性能优化和调试技巧,包括从问题表象出发进行优化、排除外部问题导致的卡顿、帧率设定、减少drawcall的方法、UI优化和图集渲染等八个理念。对于游戏程序员来说,解决游戏性能问题是一个关键的任务,本文提供了一些有用的参考价值。摘要长度为183字。 ... [详细]
  • 本文介绍了JavaScript进化到TypeScript的历史和背景,解释了TypeScript相对于JavaScript的优势和特点。作者分享了自己对TypeScript的观察和认识,并提到了在项目开发中使用TypeScript的好处。最后,作者表示对TypeScript进行尝试和探索的态度。 ... [详细]
  • Question该提问来源于开源项目:react-native-device-info/react-native-device-info ... [详细]
  • Hadoop源码解析1Hadoop工程包架构解析
    1 Hadoop中各工程包依赖简述   Google的核心竞争技术是它的计算平台。Google的大牛们用了下面5篇文章,介绍了它们的计算设施。   GoogleCluster:ht ... [详细]
author-avatar
别禳莴觞芯_737
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有