zoukankan      html  css  js  c++  java
  • Vue


    关于Vue

    https://cn.vuejs.org/
    Idea的JavaScript版本设置在ECMAScript6以上
    尤雨溪开发
    一套用于构建用户界面的渐进式框架
    核心库只关心视图层
    Soc关注点分离原则

    便于整合第三方库

    网络通信:axios(前端通信框架ajax)
    页面跳转:vue-router
    状态管理:vuex
    vue-UI:ICE,ElementUI……

    特点

    vm:数据双向绑定(相当于后端的controller)
    虚拟dom:利用内存
    计算属性:vue特色
    综合了:mvvm(angular)+dom(react)
    数据驱动,组件化
    dom监听,数据绑定

    第一个Vue程序

    Idea安装vue插件

    https://www.cnblogs.com/rain2020/p/12709370.html

    vue-first

    https://github.com/ChenCurry/vue-first.git
    判断,循环,事件,双向绑定,组件,Axios通信,计算属性,插槽slot,自定义事件内容分发

    常用属性

    v-on绑定事件,简写 @
    v-model数据双向绑定
    v-bind给组件绑定参数,简写 :

    组件内部绑定事件

    this.$emit("事件名",参数);

    第一个Vue-cli程序

    安装nodejs

    http://nodejs.cn/download/
    (vue是基于nodejs) node -v npm -v

    安装npm淘宝镜像加速器

    npm install cnpm -g

    该目录下会多出一些文件

    C:UsersasusAppDataRoaming pm ode_modules

    安装vue-cli

    cnpm install vue-cli -g
    vue list

    创建vue程序

    cd D:cangku
    vue init webpack myvue
    # 后话:在idea中新建module-->js-->vue

    安装依赖环境

    cd myvue
    npm install
    npm audit fix

    启动项目

    npm run dev

    访问

    http://localhost:8080/

    用Idea打开myvue

    开启管理员权限

    (后话:这样修改了不能破解了,完了该课学习换回去)


    Webpack

    Webpack是一个前端资源加载/打包工具。

    安装(打包工具和客户端)

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

    测试安装成功

    webpack -v
    webpack-cli -v

    新建文件夹webpack-study并用Idea打开

    hello.js

    //暴露一个方法
    exports.sayHi = function () {
        document.write("<h1>测试webpack</h1>")
    };
    exports.sayHi2 = function () {
        document.write("<h1>测试webpack</h1>")
    };
    exports.sayHi3 = function () {
        document.write("<h1>测试webpack</h1>")
    };

    main.js

    var hello = require("./hello");
    hello.sayHi();

    webpack.config.js

    module.exports = {
        entry: './modules/main.js',
        output: {
            filename: "./js/bundle.js"
        }
    };

    打包

    index.html测试

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <script src="dist/js/bundle.js"></script>
    </body>
    </html>

    Vue Router

    (myvue工程中)

    为当前项目安装

    npm install vue-router --save-dev
    npm audit fix

    便可在main.js中导入并显示声明使用

    import Vue from 'vue'
    import App from './App'
    import VueRouter from 'vue-router'
    import router from './router'//自动扫描路由配置
    
    Vue.config.productionTip = false
    
    //显示声明使用vuerouter
    Vue.use(VueRouter);
    
    new Vue({
      el: '#app',
      //配置路由
      router,
      components: { App },
      template: '<App/>'
    })

    使用路由(相当于路由的配置文件)

    import Vue from 'vue';
    import VueRouter from "vue-router";
    import Content from "../components/Content";
    import Main from "../components/Main";
    
    //安装路由
    Vue.use(VueRouter);
    
    //配置导出路由
    export default new VueRouter({
      routes: [
        {
          //路由路径
          path: '/content',
          name: 'content',
          //跳转的组件
          component: Content
        },
        {
          //路由路径
          path: '/main',
          name: 'main',
          //跳转的组件
          component: Main
        }
      ]
    })

    App.vue

    <template>
      <div id="app">
        <h1>xio xi</h1>
        <router-link to="/main">首页</router-link>
        <router-link to="/content">内容页</router-link>
        <router-view></router-view>
      </div>
    </template>
    
    <script>
    
    export default {
      name: 'App',
    }
    </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>

    部分代码略,见源码

    https://github.com/ChenCurry/myvue.git

    启动

    npm run dev

    Vue+ElementUI

    创建项目hello-vue

    命令提示符(管理员):
    cd D:cangku
    # 创建项目hello-vue
    vue init webpack hello-vue
    # 安装vue-router
    cd hello-vue npm install vue-router --save-dev # 安装element-ui npm i element-ui -S # 安装依赖 npm install
    npm audit fix # 安装SASS加速器 cnpm install sass-loader node-sass --save-dev # 启动测试 npm run dev

    用Idea打开项目

    assets:用于存放资源文件
    components:用于存放 Vue 功能组件
    views:用于存放 Vue 视图组件
    router:用于存放 vue-router 配置

    报错修改版本(先直接试试下面的步骤)

    "sass-loader": "^10.0.1",改为"sass-loader": "^7.3.1",

    重新安装/启动

    cnpm install
    cnpm run dev

    访问

    http://localhost:8080/login

     源码

    https://github.com/ChenCurry/hello-vue.git

    推荐

    https://docsify.js.org/#/

    嵌套路由

    http://localhost:8080/main

    组件+子路由+router-link+显示到router-view

    404及路由钩子

    https://github.com/ChenCurry/hello-vue.git
    cnpm install axios -s

    击石乃有火,不击元无烟!!
  • 相关阅读:
    Linux进程管理与任务计划
    Linux磁盘存储和文件系统
    Oracle Net
    Oracle常用命令
    Ansible之playbook,yaml文件详解
    ansible配置文件详解
    linux学习笔记12-lap+mysql主从+proxy
    Linux 学习笔记11-lamp+redis主从
    Linux学习笔记10-kickstart批量安装centos7
    Linux学习笔记9-ftp服务器
  • 原文地址:https://www.cnblogs.com/rain2020/p/13544556.html
Copyright © 2011-2022 走看看