Python vue坏境搭建及项目创建

vue项目坏境搭建

node ~~ python:node是用c++编写用来运行js代码的
npm(cnpm) ~~ pip:npm是一个终端应用商城,可以换国内源cnpm
vue ~~ django:vue是用来搭建vue前端项目的

1.安装node

官网下载安装包,傻瓜式安装:https://nodejs.org/zh-cn/

2. 安装cnpm

npm相当于node的应用商店,这里我们换成淘宝源保证资源的下载速度

# 换国内源,加速下载
# 管理员命令行:npm install -g cnpm --registry=https://registry.npm.taobao.org
# MacOS: sudo npm install -g cnpm --registry=https://registry.npm.taobao.org


# 索引npm的指令都可以换成cnpm
# npm install vuex => cnpm install vuex

 

 3.安装脚手架

"""
cnpm install -g @vue/cli

如果报错执行下述代码再重新安装脚手架:npm cache clean --force
"""

确认是否下载成功

vue项目创建(自定义按照下图流程即可)

1) 进入存放项目的目录
>: cd ***

2) 创建项目
>: vue create 项目名

3) 项目初始化自定义创建总结:1.有提示选择大写,没提示默认第一个即可,空格选择 回车键确认 上下键选择

 pycharm运行vue项目和插件安装

vue.js插件安装(安装后重启pycharm)

 启动 和停止

vue项目目录结构分析

├── v-proj
|    ├── node_modules      // 当前项目所有依赖,一般不可以移植给其他电脑环境
|    ├── public
|    |    ├── favicon.ico    // 标签图标
|    |    └── index.html    // 当前项目唯一的页面
|    ├── src
|    |    ├── assets        // 静态资源img、css、js
|    |    ├── components    // 小组件
|    |    ├── views        // 页面组件(由若干个小组件组成)
|    |    ├── App.vue        // 根组件
|    |    ├── main.js        // 全局脚本文件(项目的入口)
|    |    ├── router.js    // 路由脚本文件(配置路由 url链接 与 页面组件的映射关系)
|    |    └── store.js    // 仓库脚本文件(vuex插件的配置文件,数据仓库)
|    ├── README.md
└    └── **配置文件

vue组件(.vue文件,区分大小写)

# 1) template:有且只有一个根标签
# 2) script:必须将小组件对象导出,页面组件导入将小组件的export default {}字典与页面组件变量绑定,页面组件还要注册小组件  #小组件导出
<script>export default {  name: ‘HelloWorld‘,  props: {    msg: String  }}</script>   # 页面组件导入和注册小组件:import 任意变量名 from ‘小组件路径‘
export default {  components: {    k:任意变量名  }}
<script>// @ is an alias to /srcimport HelloWorld from ‘@/components/HelloWorld.vue‘

export default {  name: ‘home‘,  components: {    HelloWorld  }}</script>
# 3) style: style标签明确scoped属性,代表该样式只在组件内部起作用(样式的组件化)
<style scoped> ..</style>

全局脚本文件main.js(项目入口)

import Vue from ‘vue‘
import App from ‘./App.vue‘
import router from ‘./router‘
import store from ‘./store‘

Vue.config.productionTip = false

new Vue({
    router,
    store,
    render: h => h(App)
}).$mount(‘#app‘)

# 改写
import Vue from ‘vue‘  // 加载vue环境
import App from ‘./App.vue‘  // 加载根组件
import router from ‘./router‘  // 加载路由环境
import store from ‘./store‘  // 加载数据仓库环境

Vue.config.productionTip = false
new Vue({
    el: ‘#app‘,
    router,
    store,
    render: function (readFn) {
        return readFn(App);
    },
});

vue项目启动生命周期 与 页面组件的运用(重点)

请求过程

1) 加载mian.js启动项目
    i) import Vue from ‘vue‘ 为项目加载vue环境
    ii) import App from ‘./App.vue‘ 加载根组件用于渲染替换挂载点
    iii) import router from ‘./router‘ 加载路由脚本文件,进入路由相关配置

2) 加载router.js文件,为项目提供路由服务,并加载已配置的路由(链接与页面组件的映射关系)
    注:不管当前渲染的是什么路由,页面渲染的一定是根组件,链接匹配到的页面组件只是替换根组件中的
    <router-view></router-view>

3) 如果请求链接改变(路由改变),就会匹配新链接对应的页面组件,新页面组件会替换渲染router-view标签,替换掉之前的页面标签(就是完成了页面跳转)

router.js

# 导入页面组件
import 变量名 from ‘页面组件‘

# 路由注册
export default new Router({
    mode: ‘history‘,
    base: process.env.BASE_URL,
    routes: [
        {
            path: ‘路由地址‘,
            name: ‘任意名‘,
            component: 变量名
        },

    ]
})
App.vue(固定只写下面几行代码)
<template>
    <div id="app">
        <!-- url路径会加载不同的页面组件
            eg:/red => RegPage  | /blue => BluePage
         来替换router-view标签,完成页面的切换
         -->
        <router-view></router-view>
    </div>
</template>

全局样式文件配置

1.在(assets文件夹/css 文件夹/global.css文件) 中配置

html, body, h1, h2, ul, p {
    margin: 0;
    padding: 0;
}
ul {
    list-style: none;
}
a {
    color: black;
    text-decoration: none;
}

2.main.js文件中配置

// 配置全局样式
import ‘@/assets/css/global.css‘

封装小组件 - Nav导航栏组件

components/Nav.vue

<template>
    <div class="nav">
        <!--采用vue-router完成页面跳转,不能采用a标签(会发生页面刷新,本质就是重新加载了一次项目界面)-->
        <ul>
            <li>
                <!--<a href="/">主页</a>-->
                <router-link to="/">主页</router-link>
            </li>
            <li>
                <router-link to="/red">红页</router-link>
            </li>
            <li>
                <router-link to="/blue">蓝页</router-link>
            </li>
        </ul>
    </div>
</template>

<script>
    export default {
        name: "Nav",
    }
</script>

<style scoped>
    .nav {
        width: 100%;
        height: 60px;
        background-color: orange;
    }
    .nav li {
        float: left;
        font: normal 20px/60px ‘微软雅黑‘;
        padding: 0 30px;
    }
    .nav li:hover {
        cursor: pointer;
        background-color: aquamarine;
    }
    .nav li.active {
        cursor: pointer;
        background-color: aquamarine;
    }
</style>

小组件代码

views/HomePage.vue:RedPage.vue与BluePage都是添加下方三个步骤代码

<template>
    <div class="home">
        <!-- 3)使用Nav组件 -->
        <Nav></Nav>
    </div>
</template>

<script>
    // 1)导入Nav组件
    import Nav from ‘@/components/Nav‘
    export default {
        // 2)注册Nav组件
        components: {
            Nav,
        }
    }
</script>

页面组件代码

新增页面三步骤

1) 在views文件夹中创建视图组件

2) 在router.js文件中配置路由

3) 设置路由跳转,在指定路由下渲染该页面组件(替换根组件中的router-view标签)
views/TanPage.vue

<template>
    <div class="tan-page">
        <Nav></Nav>
    </div>
</template>

<script>
    import Nav from ‘@/components/Nav‘
    export default {
        name: "TanPage",
        components: {
            Nav
        }
    }
</script>

<style scoped>
    .tan-page {
        width: 100vw;
        height: 100vh;
        background-color: tan;
    }
</style>

视图组件

router.js

import TanPage from "./views/TanPage";
export default new Router({
    mode: ‘history‘,
    base: process.env.BASE_URL,
    routes: [
        // ...
        {
            path: ‘/tan‘,
            name: ‘tan‘,
            component: TanPage
        }
    ]
})

视图组件导入和路由注册

components/Nav.vue

<li>
    <router-link to="/tan">土页</router-link>
</li>

路由跳转

组件生命周期钩子

任何一个组件:在vue组件的script的export default导出字典中直接写钩子函数

export default {
    // ...
    beforeCreate() {
        console.log(‘组件创建了,但数据和方法还未提供‘);
        // console.log(this.$data);
        // console.log(this.$options.methods);
        console.log(this.title);
        console.log(this.alterTitle);
    },
    // 该钩子需要掌握,一般该组件请求后台的数据,都是在该钩子中完成
    // 1)请求来的数据可以给页面变量进行赋值
    // 2)该节点还只停留在虚拟DOM范畴,如果数据还需要做二次修改再渲染到页面,
    //  可以在beforeMount、mounted钩子中添加逻辑处理
    created() {
        console.log(‘组件创建了,数据和方法已提供‘);
        // console.log(this.$data);
        // console.log(this.$options.methods);
        console.log(this.title);
        console.log(this.alterTitle);
        console.log(this.$options.name);
    },
    destroyed() {
        console.log(‘组件销毁完毕‘)
    }
}

钩子函数

补充

this.$options:可以获取所有实例成员,一般用它获取自定义的实例成员
示例:获取自定义示例成员name
this.$options.name

根据请求路径高亮路由标签案例

1) router-link会被解析为a标签,用to完成指定路径跳转,但是不能添加系统事件(因为是组件标签)
2) 在js方法中可以用 this.$router.push(‘路径‘) 完成逻辑跳转
3) 在js方法中可以用 this.$route.path 拿到当前请求的页面路由

<template>
    <div class="nav">
        <!--采用vue-router完成页面跳转,不能采用a标签(会发生页面刷新,本质就是重新加载了一次项目界面)-->
        <ul>
            <li @click="changePage(‘/‘)" :class="{active: currentPage === ‘/‘}">
                <!--<a href="/">主页</a>-->
                <!--<router-link to="/">主页</router-link>-->
                主页
            </li>
            <li @click="changePage(‘/red‘)" :class="{active: currentPage === ‘/red‘}">
                <!--<router-link to="/red">红页</router-link>-->
                红页
            </li>
            <li @click="changePage(‘/blue‘)" :class="{active: currentPage === ‘/blue‘}">
                <!--<router-link to="/blue">蓝页</router-link>-->
                蓝页
            </li>
            <li @click="changePage(‘/tan‘)" :class="{active: currentPage === ‘/tan‘}">
                <!--<router-link to="/tan">土页</router-link>-->
                土页
            </li>
        </ul>
    </div>
</template>

<script>
    export default {
        name: "Nav",
        data() {
            return {
                // 没渲染一个页面,都会出现加载Nav组件,currentPage就会被重置,
                // 1)在点击跳转事件中,将跳转的页面用 数据库 保存,在钩子函数中对currentPage进行数据更新
                // currentPage: localStorage.currentPage ? localStorage.currentPage: ‘‘
                // 2)直接在created钩子函数中,获取当前的url路径,根据路径更新currentPage
                currentPage: ‘‘
            }
        },
        methods: {
            changePage(page) {
                // console.log(page);
                // 当Nav出现渲染,该语句就无意义,因为在data中将currentPage重置为空
                // this.currentPage = page;

                // 有bug,用户不通过点击,直接修改请求路径完成页面跳转,数据库就不会更新数据
                // localStorage.currentPage = page;

                // 任何一个标签的事件中,都可以通过router完成逻辑条件
                // console.log(this.$route);  // 管理路由数据
                // console.log(this.$router);  // 管理路由跳转
                this.$router.push(page);  // 路由的逻辑跳转
            }
        },
        // 当前组件加载成功,要根据当前实际所在的路径,判断单选激活标签
        created() {
            // console.log(this.$route.path);
            this.currentPage = this.$route.path;
        }
    }
</script>

<style scoped>
    .nav {
        width: 100%;
        height: 60px;
        background-color: orange;
    }
    .nav li {
        float: left;
        font: normal 20px/60px ‘微软雅黑‘;
        padding: 0 30px;
    }
    .nav li:hover {
        cursor: pointer;
        background-color: aquamarine;
    }
    .nav li.active {
        cursor: pointer;
        background-color: aquamarine;
    }
</style>

示例

原文地址:https://www.cnblogs.com/tfzz/p/11651300.html

时间: 2024-10-10 13:25:21

Python vue坏境搭建及项目创建的相关文章

大数据系列(3)——Hadoop集群完全分布式坏境搭建

前言 上一篇我们讲解了Hadoop单节点的安装,并且已经通过VMware安装了一台CentOS 6.8的Linux系统,咱们本篇的目标就是要配置一个真正的完全分布式的Hadoop集群,闲言少叙,进入本篇的正题. 技术准备 VMware虚拟机.CentOS 6.8 64 bit 安装流程 我们先来回顾上一篇我们完成的单节点的Hadoop环境配置,已经配置了一个CentOS 6.8 并且完成了java运行环境的搭建,Hosts文件的配置.计算机名等诸多细节. 其实完成这一步之后我们就已经完成了Had

selenium3+python自动化50-环境搭建(firefox)

前言 有不少小伙伴在安装selenium环境后启动firefox报错,因为现在selenium升级到3.0了,跟2.0的版本还有有一点区别的. 安装环境过程中主要会遇到三个坑: 1.'geckodriver' executable needs to be in PATH 2.Expected browser binary location, but unable to find binary in default location 3.Unsupported Marionette protoco

大数据系列(1)——Hadoop集群坏境搭建配置

前言 关于时下最热的技术潮流,无疑大数据是首当其中最热的一个技术点,关于大数据的概念和方法论铺天盖地的到处宣扬,但其实很多公司或者技术人员也不能详细的讲解其真正的含义或者就没找到能被落地实施的可行性方案,更有很多数据相关的项目比如弄几张报表,写几个T-SQL语句就被冠以“大数据项目”,当然了,时下热门的话题嘛,先把“大数据”帽子扣上,这样才能显示出项目的高大上,得到公司的重视或者高层领导的关注. 首先,关于大数据的概念或者架构一直在各方争议的背景下持续的存在着.目前,关于大数据项目可以真正被落地

【Python3.6+Django2.0+Xadmin2.0系列教程一】环境搭建及项目创建

由于工作需要,接触了大半年时间的Django+xadmin框架,一直没空对这块对进行相关的梳理.最近在同事的怂恿下,就在这分享下笔者的学习及工作经验吧. 好了,话不多说,下面开始进入正题: 环境需求: 笔者的工作系统环境:Mac 10.13.4+Python3.6.x+Django2.0.x+Xadmin2.0 因此本系列教程均是以此组合为基础展开讲解.其他系统版本也基本适用,有小部分不兼容之处请自行测试. 一.Django及xadmin安装 可以使用pip命令进行安装,或者直接下载安装包用py

一、环境搭建和项目创建

1.下载安装python 2.打开shell(windows下cmd),安装虚拟环境工具:  "pip install virtualenv".(可以通过“python -m pip install --upgrade pip”升级最新pip) 3.转到目标文件夹,创建虚拟环境:“virtualenv env” 4.启动虚拟环境: 1)打开虚拟环境下的activate脚本 2)使用命令“source env/bin/activate”. 相应使用“deactivate”可以退出虚拟环境

使用vue脚手架工具搭建vue-webpack项目

对于Vue.js来说,如果你想要快速开始,那么只需要在你的html中引入一个<script>标签,加上CDN的地址即可.但是,这并不算是一个完整的vue实际应用.在实际应用中,我们必须要一系列的工具,包括:模块化,转译,预处理,热加载,静态检测和自动化测试等.对于一个需要长期维护和大型的项目而言,这些工具是必不可少的,但是尝试配置初始化这些很痛苦.这就是我们发布vue官方提供的脚手架工具的原因,一个简单的构建工具,通过几个默认的步骤帮助你快速的构建Vue.js项目. 1.安装node环境 可以

开发坏境搭建

开发环境搭建(C++) 来自zhicloud 跳转至: 导航. 搜索 目录 [隐藏] 1整体要求 2准备工作 3编译器 4code blocks 5依赖库 5.1致云Framework 5.2boost 整体要求[编辑] 致云C++平台模块.公共代码库均只在特定环境下编译运行,因此致云模块的开发.测试.部署必须严格按照要求执行,否则将得到不可预期的结果 同时,提交版本库的代码.项目必须在本规则要求统一的环境下编译通过,以确保所有开发团队获取代码后都能快速顺利编译,提高开发效率,所有不满足要求的提

Spring基础知识1--环境搭建、bean创建、依赖注入、注解注入

一.Spring两大核心内容 1.控制反转IOC/DI:  应用本身不负责对象的创建和维护,对象和依赖对象的创建完全交给容器管理. 2.AOP(面向切面编程):通过预编译的方式,在运行期通过动态代理的方式来实现的一种技术 (1)在项目中使用AOP管理事务,事务的开启,提交,回滚 (2)在项目中管理事务的传播特性. 二.Spring的环境搭建 1.导包:   2.创建Spring的配置文件 ApplicationContext.xml 1 <?xml version="1.0" e

phonegap 4.2 环境搭建 及 项目创建 运行

安装Java 和 ADT 1.首先要安装java运行环境jdk,这个可以自行到官网下载.百度也有下载连接:( http://www.baidu.com/s?tn=baidu&ie=utf-8&f=8&wd=jdk ),这个主意要将java安装路径的bin目录加入系统或用户的环境变量path中,安装完可以在cmd命令行窗口输入java -version,看是否有反应.2.然后下载ADT(Android Development Tools),这个到官网下载:(http://develo