热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:再探vue

1.vue项目搭建搭建vue环境需要安装node软件,node是由c++编写而成,主要运行js文件或者js代码的,安装node会

1. vue项目搭建

  搭建vue环境需要安装node软件,node是由c++编写而成,主要运行js文件或者js代码的,安装node会自动安装一个管理器叫npm,建议换源下载,国外的网站较慢(比如cnpm,这个叫淘宝源),最后下载vue

  1. 下载node

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

技术图片

  2. 换源安装cnpm

   npm install -g cnpm --registry=https://registry.npm.taobao.org

  技术图片

  3. 安装脚手架

  cnpm install -g @vue/cli

技术图片 

  注:2或3终端安装失败时,可以清空 npm缓存 再重复执行失败的步骤
  npm cache clean --force

2. 创建项目

  1. 进入存放项目的目录

  cd 项目的路径

  2. 创建项目  vue create 项目名

  3. 项目初始化

技术图片

 

3. 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
└ └── **配置文件

  

4. vue组件由哪几部分组成





1) template:有且只有一个根标签
2) script:必须将组件对象导出 export default {}
3) style: style标签明确scoped属性,代表该样式只在组件内部起作用(样式的组件化)

  

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


在node_moduls library root 模块中导入以下模块
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); // 将组件文件读成字符串形式,渲染挂载点
},
});

  

6. vue项目启动生命周期与页面组件的运用


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

2) 加载router.js文件,为项目提供路由服务,并加载已配置的路由(链接与页面组件的映射关系)
注:不管当前渲染的是什么路由,页面渲染的一定是根组件,链接匹配到的页面组件只是替换根组件中的
这个标签有vue.router进行提供, 比如我们走red这个路由, 自然而然的会拿出RegPage这个组件,他就会把PegPage这个组件替换成, 如果走blue这个路由, 他就会拿出BluePage这个组件来进行替换RedPage这个组件, 进而实现页面的跳转

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

  参与文件

  main.js: 该文件内容不变

  App.vue



  views/RedPage.vue




拓展: vm : 相对于视窗的宽度或高度, 取决于哪个更小

  views/BluePage.vue





  router.js

import Vue from ‘vue‘
import Router from ‘vue-router‘
import Home from ‘./views/Home.vue‘
import RedPage from "./views/RedPage";
import BluePage from "./views/BluePage";
Vue.use(Router);
export default new Router({
mode: ‘history‘,
base: process.env.BASE_URL,
routes: [
{
path: ‘/‘,
name: ‘home‘,
component: Home
},
{
path: ‘/red‘,
name: ‘red‘,
component: RedPage
},
{
path: ‘/blue‘,
name: ‘blue‘,
component: BluePage
}
]
})

  

7.全局样式文件配置

  assets/css/global.css

html, body, h1, h2, ul, p {
margin: 0;
padding: 0;
}
ul {
list-style: none;
}
a {
color: black;
text-decoration: none;
}
// list-style属性是设置list-style-type, list-style-image 和 list-style-position的简写属性

  main.js中新增

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

  

8. 封装小组件==> Nav导航栏组件

  components/Nav.vue





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




  

新增页面三步骤

1. 在views文件夹中创建视图组件
2. 在router.js文件中配置路由
3. 设置路由跳转,在指定路由下渲染该组件(替换根组件中的router-view标签)

  views/ TanPage.vue





  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


  • 土页


  •   

    9. 组件生命周期钩子


    1)一个组件从创建到销毁的整个过程,就称之为组件的生命周期
    2)在组件创建到销毁的过程中,会出现众多关键的时间节点,如 组件要创建了、组件创建完毕了、组件数据渲染完毕了、组件要被销毁了、组件销毁完毕了 等等时间节点,每一个时间节点,vue都为其提供了一个回调函数(在该组件到达该时间节点时,就会触发对应的回调函数,在函数中就可以完成该节点需要完成的业务逻辑)
    3)生命周期钩子函数就是 vue实例 成员

      任何一个组件: 在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(‘组件销毁完毕‘)
    }
    }

      

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


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

      components/Nav.vue





      

     


    推荐阅读
    • 深入理解Vue.js:从入门到精通
      本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
    • Node.js 入门指南(一)
      本文介绍了Node.js的安装步骤、如何创建第一个应用程序、NPM的基本使用以及处理回调函数的方法。通过实际操作示例,帮助初学者快速掌握Node.js的基础知识。 ... [详细]
    • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
    • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
    • 深入理解Tornado模板系统
      本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
    • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
    • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
    • Android LED 数字字体的应用与实现
      本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
    • RecyclerView初步学习(一)
      RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
    • 从 .NET 转 Java 的自学之路:IO 流基础篇
      本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
    • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
      本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
    • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
    • 深入解析ES6至ES8的新特性与应用
      本文详细介绍了自2015年发布的ECMAScript 6.0(简称ES6)以来,JavaScript语言的多项重要更新,旨在帮助开发者更好地理解和利用这些新特性进行复杂应用的开发。 ... [详细]
    • golang常用库:配置文件解析库/管理工具viper使用
      golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
    • 本文将详细介绍如何在Bootstrap 5中使用五种不同的表单控件样式,包括输入框、选择器和文本区域等元素。 ... [详细]
    author-avatar
    S_o_m_n_u_211
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有