草庐IT

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

小张快跑。 2025-05-20 原文

一、使用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的优点?

  • 速度快。速度快主要来自以下两个方面:
  1.  并行安装:无论npm还是Yarn在执行包的安装时,都会执行一系列任务。npm是按照队列执行每个package,也就是说必须要等到当前package安装完成后,才能继续后续的安装。而Yarn是同步执行所有的任务,提高了性能
  2. 离线模式:如果之前已经安装过一个软件包,用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命令对比

npmyarn
npm unstallyarn
npm install react --save

yarn add react

npm uninstall react --save

yarn remove react

npm install react --save-devyarn add react --dev
npm 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<name>

        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 文件即可开始使用。

<!-- 引入样式 -->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<!-- 引入组件库 -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>

        脚手架中的引入

  • 全局引入

(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组件

 <el-button  type="primary">按钮</el-button>

         由于全局引入后,会导致我们的项目在打包时,将所有的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通用后台管理系统】(一)项目搭建的更多相关文章

  1. ruby - i18n Assets 管理/翻译 UI - 2

    我正在使用i18n从头开始​​构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在ruby​​onrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi

  2. ruby - 如何在 buildr 项目中使用 Ruby 代码? - 2

    如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby​​

  3. ruby-on-rails - 项目升级后 Pow 不会更改 ruby​​ 版本 - 2

    我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby​​版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby​​版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘

  4. ruby-on-rails - 新 Rails 项目 : 'bundle install' can't install rails in gemfile - 2

    我已经像这样安装了一个新的Rails项目:$railsnewsite它执行并到达:bundleinstall但是当它似乎尝试安装依赖项时我得到了这个错误Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcheckingforlibkern/OSAtomic.h...yescreatingMakefilemake"DESTDIR="cleanmake"DESTDIR="

  5. ruby-on-rails - 获取 inf-ruby 以使用 ruby​​ 版本管理器 (rvm) - 2

    我安装了ruby​​版本管理器,并将RVM安装的ruby​​实现设置为默认值,这样'哪个ruby'显示'~/.rvm/ruby-1.8.6-p383/bin/ruby'但是当我在emacs中打开inf-ruby缓冲区时,它使用安装在/usr/bin中的ruby​​。有没有办法让emacs像shell一样尊重ruby​​的路径?谢谢! 最佳答案 我创建了一个emacs扩展来将rvm集成到emacs中。如果您有兴趣,可以在这里获取:http://github.com/senny/rvm.el

  6. Ruby 从大范围中获取第 n 个项目 - 2

    假设我有这个范围:("aaaaa".."zzzzz")如何在不事先/每次生成整个项目的情况下从范围中获取第N个项目? 最佳答案 一种快速简便的方法:("aaaaa".."zzzzz").first(42).last#==>"aaabp"如果出于某种原因你不得不一遍又一遍地这样做,或者如果你需要避免为前N个元素构建中间数组,你可以这样写:moduleEnumerabledefskip(n)returnto_enum:skip,nunlessblock_given?each_with_indexdo|item,index|yieldit

  7. ruby-on-rails - 事件管理员日期过滤器日期格式自定义 - 2

    是否有简单的方法来更改默认ISO格式(yyyy-mm-dd)的ActiveAdmin日期过滤器显示格式? 最佳答案 您可以像这样为日期选择器提供额外的选项,而不是覆盖js:=f.input:my_date,as::datepicker,datepicker_options:{dateFormat:"mm/dd/yy"} 关于ruby-on-rails-事件管理员日期过滤器日期格式自定义,我们在StackOverflow上找到一个类似的问题: https://s

  8. 电脑0x0000001A蓝屏错误怎么U盘重装系统教学 - 2

      电脑0x0000001A蓝屏错误怎么U盘重装系统教学分享。有用户电脑开机之后遇到了系统蓝屏的情况。系统蓝屏问题很多时候都是系统bug,只有通过重装系统来进行解决。那么蓝屏问题如何通过U盘重装新系统来解决呢?来看看以下的详细操作方法教学吧。  准备工作:  1、U盘一个(尽量使用8G以上的U盘)。  2、一台正常联网可使用的电脑。  3、ghost或ISO系统镜像文件(Win10系统下载_Win10专业版_windows10正式版下载-系统之家)。  4、在本页面下载U盘启动盘制作工具:系统之家U盘启动工具。  U盘启动盘制作步骤:  注意:制作期间,U盘会被格式化,因此U盘中的重要文件请注

  9. 【鸿蒙应用开发系列】- 获取系统设备信息以及版本API兼容调用方式 - 2

    在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList​()Obt

  10. kvm虚拟机安装centos7基于ubuntu20.04系统 - 2

    需求:要创建虚拟机,就需要给他提供一个虚拟的磁盘,我们就在/opt目录下创建一个10G大小的raw格式的虚拟磁盘CentOS-7-x86_64.raw命令格式:qemu-imgcreate-f磁盘格式磁盘名称磁盘大小qemu-imgcreate-f磁盘格式-o?1.创建磁盘qemu-imgcreate-fraw/opt/CentOS-7-x86_64.raw10G执行效果#ls/opt/CentOS-7-x86_64.raw2.安装虚拟机使用virt-install命令,基于我们提供的系统镜像和虚拟磁盘来创建一个虚拟机,另外在创建虚拟机之前,提前打开vnc客户端,在创建虚拟机的时候,通过vnc

随机推荐