vue前端工程的搭建


Posted in Vue.js onMarch 31, 2021

一、用vue-cli搭建前端工程

1、什么是vue-cli

vue-cli 官方提供的一个脚手架,用于快速生成一个 vue 的项目模板;

2、搭建环境准备

  • 安装node.js 官方网址: http://nodejs.cn/download/

    • node -vnpm -v 用于检测是否安装成功
  • 安装淘宝镜像加速器:

    npm install cnpm -g
  • 安装vue-cli

    cnpm install vue-cli -g
    #查看是否安装成功
    vue list

3.vue-cli项目的搭建

1.选择一个盘区建立一个空文件夹,用于存放当前项目

2.用cmd命令进入当前新建空文件下,执行

vue init webpack xxx                   xxx表示项目名

3.进入项目名中,建立依赖包

cd xxx 
npm install  
npm run dev

4.使用webpack打包项目

4.1 什么是webpack?

WebPack 是一款模块加载器兼打包工具,它能把各种资源,如 JS、JSX、ES6、SASS、LESS、图片等都作为模块来处理和使用。

4.2 安装webpack

npm install webpack -g
npm install webpack-cli -g

测试是否安装成功

webpack -v
webpack-cli -v

5.使用webpack

在命令台输入:

webpack

6.vue-router路由的使用

6.1 什么是vue-router?

Vue Router是Vue.js官方的路由管理器(路径跳转),负责页面的跳转。

6.2 vue-router的功能

  • 嵌套的路由/视图表
  • 路由参数、查询、通配符
  • 模块化的、基于组件的路由配置

6.3 vue-router的安装
打开命令行工具,进入项目目录,输入下面命令:

npm install vue-router --save-dev

安装完成后,在项目的包路径下,会产生一个vue-router包

6.4 vue-router 案例实现

1、在src的component目录下新建content.vue,main.vue,sun.vue,在src下建立router,

vue前端工程的搭建

2.sun.vue

<template>
    <h1>sun shile</h1>
</template>

<script>
    export default {
        name: "sun"
    }
</script>

<style scoped>

</style>

3.index.html

import Vue from 'vue'
import VueRouter from "vue-router";
import content from "../components/content"
import main from "../components/main"
import sun from "../components/sun"

//安装路由
Vue.use(VueRouter)


//配置导出路由
export default new VueRouter({
  routes:[
    {
      //路由路径
        path:'/content',
      //跳转的组件
      component:content
    },
  {
    //路由路径
    path:'/main',
    //跳转的组件
    component:main
  },
    {
      //路由路径
      path:'/sun',
      //跳转的组件
      component:sun
    }
  ]
});

4.在main.js中配置路由

import Vue from 'vue'
import App from './App'
import router from './router' //自动扫描里面的路由布置
Vue.config.productionTip = false

new Vue({
  el: '#app',
  //配置路由
  router,
  components: { App },
  template: '<App/>'
})

5.App.vue

<template>
  <div id="app">
    <h1>study</h1>
    <router-link to="/main">首页</router-link>
    <router-link to="/content">内容项</router-link>
    <router-link to="/sun">其他项</router-link>
    <router-view></router-view>
  </div>
</template>

<script>
import content from './components/content'
export default {
  name: 'App',
  components:{
    content
  }

}
</script>

<style>
#app {
  font-family: 'Avenir', Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

6.启动 npm run dev

vue前端工程的搭建

二、vue + ElementUI

创建工程目录:

vue init webpack project1

安装项目依赖,vue-router,element-ui,sass-loader和node-sass等插件

#进入工程目录
cd project1
# 安装依赖
npm install
# 安装 vue-router
npm install vue-router --save-dev
# 安装 element-ui
npm i element-ui -s
# 安装SASS加载器
npm install --save-dev sass-loader  
npm install --save-dev node-sass  
# 项目启动
npm run dev

2.1.Npm命令解释

  • npm install moduleName:安装模块到项目目录
  • npm install -g moduleName:-g 的意思是将模块安装到全局,具体安装到磁盘的哪个位置,要看 npm config prefix的位置
  • npm install moduleName -save:–save的意思是将模块安装到项目目录下,并在package文件的dependencies节点写入依赖,-S为该命令的缩写
  • npm install moduleName -save-dev:–save-dev的意思是将模块安装到项目目录下,并在package文件的devDependencies节点写入依赖,-D为该命令的缩写

2.1、Element的使用

在main.js中引入

import Vue from 'vue'
import App from './App'
//自动扫描里面的路由布置
import router from './router' 
//导入elementUI
import ElementUI from "element-ui"
//导入element css
import 'element-ui/lib/theme-chalk/index.css'

Vue.use(router);
Vue.use(ElementUI)


Vue.config.productionTip = false

new Vue({
  el: '#app',
  router,
  render: h => h(App),//ElementUI规定这样使用
})

案例实现:

1.在src目录下创建一个components文件夹,该文件下存放vue组件。

main.vue

<template>
  <h1>首页</h1>
</template>
<script>
    export default {
        name: "Main"
    }
</script>
<style scoped>
</style>

login.vue(element-ui)

<template>
  <div>
    <el-form ref="loginForm" :model="form" :rules="rules" label-width="80px" class="login-box">
      <h3 class="login-title">欢迎登录</h3>
      <el-form-item label="账号" prop="username">
        <el-input type="text" placeholder="请输入账号" v-model="form.username"/>
      </el-form-item>
      <el-form-item label="密码" prop="password">
        <el-input type="password" placeholder="请输入密码" v-model="form.password"/>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" v-on:click="onSubmit('loginForm')">登录</el-button>
      </el-form-item>
    </el-form>

    <el-dialog
      title="温馨提示"
      :visible.sync="dialogVisible"
      width="30%"
      :before-close="handleClose">
      <span>请输入账号和密码</span>
      <span slot="footer" class="dialog-footer">
        <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
      </span>
    </el-dialog>
  </div>
</template>

<script>
  export default {
    name: "Login",
    data() {
      return {
        form: {
          username: '',
          password: ''
        },

        // 表单验证,需要在 el-form-item 元素中增加 prop 属性
        rules: {
          username: [
            {required: true, message: '账号不可为空', trigger: 'blur'}
          ],
          password: [
            {required: true, message: '密码不可为空', trigger: 'blur'}
          ]
        },

        // 对话框显示和隐藏
        dialogVisible: false
      }
    },
    methods: {
      onSubmit(formName) {
        // 为表单绑定验证功能
        this.$refs[formName].validate((valid) => {
          if (valid) {
            // 使用 vue-router 路由到指定页面,该方式称之为编程式导航
            this.$router.push("/main");
          } else {
            this.dialogVisible = true;
            return false;
          }
        });
      }
    }
  }
</script>

<style lang="scss" scoped>
  .login-box {
    border: 1px solid #DCDFE6;
    width: 350px;
    margin: 180px auto;
    padding: 35px 35px 15px 35px;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    box-shadow: 0 0 25px #909399;
  }

  .login-title {
    text-align: center;
    margin: 0 auto 40px auto;
    color: #303133;
  }
</style>

3,创建路由(在src目录下创建router文件夹, 并在router 目录下创建一个名为 index.js 的 vue-router 路由配置文件)

import Vue from "vue";
import Router from "vue-router";
import Main from "../views/Main";
import Login from "../views/Login";

Vue.use(Router);

export default new Router({
  routes: [
    {
      path: '/main',
      component: Main
    },
    {
      path: '/login',
      component: Login
    }
  ]
});

4.在main.js中配置相关信息

5.在App.vue中配置显示视图

<template>
  <div id="app">
    <router-link to="/login">login</router-link>
    <router-view></router-view>
  </div>
</template>
<script>
export default {
  name: 'App',
}
</script>

6.测试运行

npm run dev

登录界面显示

vue前端工程的搭建

==注:==如果sass-loader版本引发错误,可在package.json文件里的 "sass-loader"里更换版本,例如:“sass-loader”: “^7.3.1”。

实用工具:
docsify文档生成工具 .

Vue.js 相关文章推荐
vuex的数据渲染与修改浅析
Nov 26 Vue.js
vue3.0中setup使用(两种用法)
Dec 02 Vue.js
vue使用echarts图表自适应的几种解决方案
Dec 04 Vue.js
Vue-router中hash模式与history模式的区别详解
Dec 15 Vue.js
Vue3 实现双盒子定位Overlay的示例
Dec 22 Vue.js
梳理一下vue中的生命周期
Dec 30 Vue.js
vue 动态生成拓扑图的示例
Jan 03 Vue.js
vue3.0 自适应不同分辨率电脑的操作
Feb 06 Vue.js
vue实现可移动的悬浮按钮
Mar 04 Vue.js
vue中使用mockjs配置和使用方式
Apr 06 Vue.js
vue实现列表垂直无缝滚动
Apr 08 Vue.js
解决vue-router的beforeRouteUpdate不能触发
Apr 14 Vue.js
vue中data改变后让视图同步更新的方法
vue3如何优雅的实现移动端登录注册模块
开发一个封装iframe的vue组件
如何让vue长列表快速加载
Vue3 Composition API的使用简介
vue+django实现下载文件的示例
vue路由实现登录拦截
You might like
DEDE采集大师官方留后门的删除办法
2011/01/08 PHP
解析thinkphp import 文件内容变量失效的问题
2013/06/20 PHP
析构函数与php的垃圾回收机制详解
2013/10/28 PHP
php实现图片缩放功能类
2013/12/18 PHP
php无限极分类递归排序实现方法
2014/11/11 PHP
php使用iconv中文截断问题的解决方法
2015/02/11 PHP
php实现的IMEI限制的短信验证码发送类
2015/05/05 PHP
yii实现model添加默认值的方法(2种方法)
2016/01/06 PHP
PHP实现Unicode编码相互转换的方法示例
2020/11/17 PHP
[IE&amp;FireFox兼容]JS对select操作
2007/01/07 Javascript
js禁止小键盘输入数字功能代码
2011/08/01 Javascript
JS中Date日期函数中的参数使用介绍
2014/01/02 Javascript
Javascript高级技巧分享
2014/02/25 Javascript
javascript实现左右控制无缝滚动
2014/12/31 Javascript
JS实现带关闭功能的阿里妈妈网站顶部滑出banner工具条代码
2015/09/17 Javascript
JavaScript中最常见的三个面试题解析
2017/03/04 Javascript
使用JavaScript根据图片获取条形码的方法
2017/07/04 Javascript
layui框架中layer父子页面交互的方法分析
2017/11/15 Javascript
利用SpringMVC过滤器解决vue跨域请求的问题
2018/02/10 Javascript
angular动态表单制作
2018/02/23 Javascript
基于elementUI实现图片预览组件的示例代码
2019/03/31 Javascript
微信小程序Page中data数据操作和函数调用方法
2019/05/08 Javascript
jQuery实现input输入框获取焦点与失去焦点时提示的消失与显示功能示例
2019/05/27 jQuery
Servlet返回的数据js解析2种方法
2019/12/12 Javascript
Node Express用法详解【安装、使用、路由、中间件、模板引擎等】
2020/05/13 Javascript
JavaScript监听键盘事件代码实现
2020/06/03 Javascript
基于JavaScript的数据结构队列动画实现示例解析
2020/08/06 Javascript
Python实现带百分比的进度条
2016/06/28 Python
Python中super函数的用法
2017/11/17 Python
python网络爬虫 CrawlSpider使用详解
2019/09/27 Python
CSS3 @media的基本用法总结
2019/09/10 HTML / CSS
铭立家具面试题
2012/12/06 面试题
小学教师师德师风个人整改措施
2014/09/18 职场文书
财政局党的群众路线教育实践活动整改方案
2014/09/21 职场文书
自荐信怎么写
2015/03/04 职场文书
Python语言中的数据类型-序列
2022/02/24 Python