zoukankan      html  css  js  c++  java
  • vue项目搭建和开发流程 vue项目配置ElementUI、jQuery和Bootstrap环境、跨域问题

    一、VUE项目的搭建

    • 步骤:
    1.环境搭建——》2.创建项目并启动项目——》
    

    1. 环境搭建

    • 共有3步
    # 1. 安装node
    去官网下载安装包,直接安装(官网:https://nodejs.org/zh-cn/)
        
    # 2. 安装cnpm   
    到command终端中,输入下面命令即可
    npm install -g cnpm --registry=https://registry.npm.taobao.org
        
    # 3. 安装脚手架
    到command终端中,输入下面命令即可
    cnpm install -g @vue/cli  
    
    # 清空缓存 (当前面的安装过程出错时,要先清空缓存,再重新安装)
    到command终端中,输入下面命令即可
    npm cache clean --force
    

    2. 项目的创建和启动

    • 注意:创建vue项目,用终端来的命令式创建最合适,不要用编辑器来创建
    # 1. 在command终端中,先切换到项目要创建的路径下
    
    # 2. 创建项目
    vue create 项目名
    
    # 在上面的第2步中,输入创建命令后还有一些配置,按照下面的图片操作即可(其中键盘上的上下方向键来选择选项,空格来确定选择)
    
    # 3. 启动项目
    启动项目之前,***一定要切换到项目根目录下***,使用终端启动时,输入下面的命令
    npm run serve  # ********一定要注意是serve ,最后没有r 
    
    
    
    • 第二步配置截图
    • 图一:

    • 图二:

    • 图三:

    • 图四:

    • 图五:

    二、 开发项目

    • 在vue项目创建成功后,基本的项目框架已经搭建好了。我们只需要用一个IDE(集成开发环境)打开项目就可以进行项目开发了。这里我们用pycharm来开发vue项目。

    1. 配置vue项目启动功能

    • 使用pycharm开发vue项目,这里我们要配置项目启动的功能,如下图。

    • 图一:

    • 图二:

    • 图三:

    • 图四:

    2. 开发vue项目

    (1)项目文件的作用

    1. node_modules : 项目的依赖(不同电脑依赖需要重新构建),我们不用管

    2. public : 存放项目的页面(因为vue框架是单页面开发,所以只含有一个index默认的页面),我们也不用动

    3. src : 存放与项目本身相关的文件 。我们主要是在这个文件夹中开发。

      • assets:存放项目的静态文件(如导入的css,js等模块插件)

      • components:存放项目的小组件(与views文件夹中的组件是子父组件的关系,传参通过子传父或父传子的方式传参。)

      • router:存放项目的路由配置(路由与页面组件对应关系)

      • views:存放项目的页面组件(其中的组件与组件之间的传参通过路由传参的方法传参)

      • App.vue文件:项目的根组件,内部固定5行代码。(我们在views中自定义的页面组件最后都是将根组件的<router-view />替换掉,进行渲染)

        • <!--App.vue的5行代码-->
          
          <template>
            <div id="app">
              <router-view/>  <!--完成页面组件的占位-->
            </div>
          </template>
          
      • main.js :项目总脚本文件(配置所有环境,加载根组件)(全局类型的环境都在改文件中配置)

        • *****对于导入文件,使用import和require都可,一般媒体文件用require来导入,而import和from联用,可以起别名。*****
              
          *****Vue.prototype.属性和Vue.use()功能相同,都是配置全局环境是使用的,Vue.prototype一般用来定义属性,在全局组件中用this可以访问到,Vue.use()一般用来配置是方法,直接在全局使用use括号内的方法名字即可。
          
          // 1. 在main.js文件中配置全局js
          import settings from '@/assets/js/settings'  // settings文件是assets文件夹下的
          Vue.prototype.$settings = settings;
          
          // 2. 在main.js文件中配置全局css
          
          require('@/assets/css/global.css');  // global.css文件是assets文件夹下
          
          // 在main.js文件中配置全局element-ui环境
          
          import ElementUI from 'element-ui';
          import 'element-ui/lib/theme-chalk/index.css';
          Vue.use(ElementUI);
          
          
          
          

    (2)vue项目开发流程

    # 1. 在views文件夹中,创建页面组件
    
    # 2. 在router的index.js中配置页面组件的路由
    
    # 3. 继续书写创建的页面组件,如果包含小组件,则需要在页面组件下方导入并挂载,数据通过vue组件的生命周期钩子来获取后端响应的数据
    
    
    

    (3)vue项目的请求生命周期

    • 浏览器对vue项目的url发送请求——》
    • router插件通过映射加载对应的页面组件——》
    • 页面组件向后端url发送ajax请求,拿到响应数据——》
    • 页面组件替换App.vue文件中的<router-view />占位符——》
    • App.vue最后把所有的模板和数据渲染到public文件夹中的index.html的根组件挂载点中——》
    • 浏览器进行对index.html页面的展示

    三、vue项目中的功能

    1. 路由相关的标签和方法

    标签:
    <!-- 该标签完成页面组件的占位 -->
    <router-view></router-view>   
    <!--该标签可以写成单标签。组件标签也可以写成单标签-->
    
    
    <!-- 该标签完成路由跳转 -->
    <router-link></router-link>
    
    
    方法:
    <!-- 该方法完成逻辑中的路由跳转 -->
    $router.push('页面组件路由')
    
    <!-- 该方法完成路由前进后退的步数,可以为负数 -->
    $router.go(整数)
    

    2. 路由配置

    • 在页面组件创建完成后,就要取router文件夹的index.js文件中配置页面组件的路由

    • vue项目的路由配置允许我们可以对一个页面组件配置多个url(通过重定向的方法)

    (1)无路由传参的路由配置方法

    // 加入现在有一个新创建的页面组件 Home.vue
    
    // 在router文件夹的index.js中
    
    1. 先导入页面组件
    import 组件别名 from '..views/Home.vue'
    
    2. 书写页面路由(在const routes中添加新路由)
    
    // 下面的两种配置都可以访问Home.vue页面组件
    
    // 1. 正常配置
      {
        path: '/home',
        name: 'home',
        component: Home
      },
    // 2. 重定向配置      
      {
        path: '/index',
        redirect:'/home'
      },
    
    
    

    (2)路由传参的路由配置方法

    • 只是与无路由传参时的 path 的值写法有差异,其他不变
    • 有两种路由传参的方式
    • 方式一:
    // 方式一:拼接式参数
    1.标签跳转携带参数:
    to="/user?pk=1" ,pk是键值对的key
    
    2.对应逻辑跳转携带参数:
    this.$router.push('/user?pk=1')
    
    3.对应的页面路由书写方式:
    path: '/user'
    
    // 方式一对应的取值方式:
    this.$route.query.pk
    
    • 方式二:
    // 方式二:有名分组式参数
    
    1.标签跳转携带参数:
    to="/user/1"
    
    2.对应逻辑跳转携带参数:
    this.$router.push('/user/1')
    
    3.对应页面路由书写方式:*****这里与无路由传参的路由书写方式有区别********
    path: '/user/:pk' 
    
    // 方式二对应的取值方式:
    this.$route.params.pk
    

    3. 页面的跳转功能

    • 共有两种方式:
      • 标签跳转
      • 逻辑跳转(即路由跳转)

    (1)标签跳转

    <router-link to="页面路由">用户页</router-link>  <!-- 使用router-link标签,完成标签跳转-->
    
    <!-- router-link 标签渲染到浏览器中就是一个a标签-->
    

    (2)逻辑跳转(路由跳转)

    this.$router.push('页面路由')  // 完成逻辑跳转,主要是在事件中完成跳转
    

    4. 项目组件中的小知识点

    (1)组件样式

    // 组件中,内部书写的style标签中,要有scoped属性,表示让当前组件中的样式使用本组件style中定义的样式,这样的话,之后即使与全局样式重名,也没关系。
    <style scoped>
    	样式代码
    </style>
    

    (2)vue前端项目和django后端

    对于vue项目向django后端请求url时,必须书写完全的django视图函数的绝对路径。

    四、JS原型

    // 利用JS原型,在vue项目中,我们可以产生一个可以在全局的vue实例都生效的属性。
    
    // 定义方式:
    // 在vue项目的main.js文件中:
    
    Vue.prototype.属性名 = 属性值(或变量);  // 这样就可以在vue项目的任意vue实例的中都可以访问到
    

    五、vue组件生命周期钩子

    • 组件的生命周期钩子就是:组件从创建到销毁的整个生命周期中特殊时间节点对应的回调方法

    • 常用的生命周期钩子

    beforeCreate(){}  // 组件要创建之前
    
    created(){}  // 组件创建成功  向后台发送数据请求,一般是加载快、比较小的数据
    
    beforeMount(){}  // 组件要加载之前
    
    mounted(){}  // 组件加载完成  ***特别耗时的数据请求,可以延后到组件初步加载成功后,再慢慢请求***
    
    beforeUpdate(){}  // 项目中任意变量要变化之前
    
    updated(){}  // 项目中任意变量刚变化之后
    
    beforeDestroyed(){}  // 组件要销毁之前
    
    destoryed(){}  // 组件销毁完成
    

    六、vue的ajax插件:axios

    // 配置步骤:
    
    1. 安装插件:在项目根目录下(一定要在项目目录下),输入命令安装插件
    
    cnpm install axios
    
    2. 在项目的main.js中配置
    
    import axios from 'axios'
    Vue.prototype.$axios = axios;  // 利用JS原型,在全部的组件中都可以访问到axios插件
    
    3. 在一个组件的逻辑中发送ajax请求实例
    
    this.$axios({
            url: 'http://127.0.0.1:8000/cars/',  // 后端url
            method: 'get',  // 请求方式
        }).then(response => {  // 回调函数,一定要用箭头函数
            console.log(response);
            // this.cars = response.data;
        }).catch(error => {  // 捕捉错误,网络状态码为4xx、5xx
            console.log(error);
        });
    
    

    七、vue+django的项目的CORS实现

    1. 为什么有跨域问题

    • 同源:http协议相同、ip服务器地址相同、app应用端口相同

    • 跨域:协议、ip地址、应用端口只要有一不同就是跨域

    • 跨域问题主要出现在前后端分离的项目中。因为浏览器和django都是同源策略,所以存在跨域问题。即浏览器和django后端都各自只会对同一个域的资源进行请求和响应。

    • 在vue项目中,

      • 浏览器请求的是vue项目的链接地址,——》
      • 链接地址对应vue的组件中再访问后端对应的链接地址——》
      • 后端链接地址响应数据返回给vue项目的回调函数,就出现了跨域问题

    2. django解决cors问题的方法

    # 步骤:
    
    # djan项目中:
    
    # 1. django 安装cors模块:
    pip install django-cors-headers
    
    # 2. 在settings配置(注册app,注册中间件)
    
    INSTALLED_APPS = [
            
            'corsheaders'
        ]
    
    MIDDLEWARE = [
            
            'corsheaders.middleware.CorsMiddleware'
        ]
        
    # 3. 在settings开启允许所有的跨域  
    
    CORS_ORIGIN_ALLOW_ALL = True
    

    八、 vue配置ElementUI

    • ElementUI是饿了么的开源第三方模块,作用和Bootstrap一样,因为饿了么全是由vue框架开发成的,所以ElementUI完美适应vue项目
    • 配置ElementUI步骤
    1. 安装插件(一定要在vue项目目录下),代替Bootstrap的下载到本地操作
    cnpm install element-ui
    
    2. 在main.js中配置
    import ElementUI from 'element-ui';
    import 'element-ui/lib/theme-chalk/index.css';
    Vue.use(ElementUI);
    
    3. 使用
    直接复制粘贴到组件的模板中即可
    

    九、vue配置jQuery和Bootstrap环境

    1. 配置jQuery环境

    1. 安装jQuery
    cnpm install jQuery
    
    2. vue项目在配置jQuery环境时,需要在vue.config.js文件中配置,如果vue项目没有该文件,则在vue项目根目录下手动创建
    
    3. vue.config.js文件中书写
    
    const webpack = require("webpack");
    
    module.exports = {
        configureWebpack: {
            plugins: [
                new webpack.ProvidePlugin({
                    $: "jquery",  // $ 表示的就是jQuery中的$
                    jQuery: "jquery",
                    "window.jQuery": "jquery",
                    Popper: ["popper.js", "default"]
                })
            ]
     		}
    };
    

    2. 配置Bootstrap环境

    1. 安装Bootstrap
    
    cnpm install bootstrap@3  // @3表示版本号,在终端中给python解释器安装则是 pip install bootstrap==3 ,3默认是3点几版本中最稳定的那个版本
    
    2. main.js文件中配置
    
    import "bootstrap"
    import "bootstrap/dist/css/bootstrap.css"
    
  • 相关阅读:
    [多线程学习笔记]条件变量
    [多线程学习笔记]互斥量
    [多线程学习笔记]线程生命周期
    多定时器队列
    双向环形链表
    多目录,多可执行文件的Makfile的编写
    大工匠
    从零开始打造我的计算机系统【运行效果】
    从零开始打造我的计算机系统【交叉汇编器】
    C中的回调函数
  • 原文地址:https://www.cnblogs.com/Mcoming/p/12075527.html
Copyright © 2011-2022 走看看