当前位置: 首页 > news >正文

VUE笔记(一)初识vue

一、vue的简介

1、什么是vue

官网地址:Vue.js

Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架

  • 构建用户界面:之前在学习vue之前通过原生js对DOM操作进行构建用户界面的

使用原生js构建用户界面的不足
- 没有规范,统一性不强,不利于团结写作开发
- 大量的DOM操作,开发效率很低
- 没有性能优化
  • 渐进式:声明式渲染+组件系统(vue的核心)+客户端路由+状态机+工具链等部分组成

渐进式:你可以在自己的项目只使用vue的一部分内容,不需要全部使用,这个vue不强制随着项目的变大,大家可以将页面中公共部分封装成组件,然后调用组件,这样可以提高开发效率在随着项目的变大,需要客户端路由+状态机
  • 框架:框架是应用程序的半成品,框架内已经将公共的部分完成了,程序使用框架的好处

    • 快速的提高开发效率

    • 程序员不用关注非核心内容,只关注业务本身

    • 框架规范行为,让代码统一性变得更强

2、特点

优点

  • 声明式编程,不需要程序员编写大量的DOM就能够完成页面的构建

  • 使用组件模式,可以让代码进行复用,增强代码的可维护性

  • 采用虚拟DOM+diff,使得按需更新,不需要构建全部DOM操作

  • vue是一个轻量级的一个框架,相对与其他框架更好容易上手

缺点

  • 首屏加载速度慢

  • VUE的网站不利于SEO优化

3、vue的作者

尤雨溪(Evan You),前端框架 Vue.js 作者,独立开源开发者,现居美国新泽西。曾就职于 Google Creative Labs 和 Meteor Development Group。由于工作中大量接触开源的 Java 项目,最后自己也走上了开源之路,现在全职开发和维护 Vue.js

4、vue版本情况

  • 2013年Evan You收到了Anglur启发,开发出来了Seed,后来在同年12月份,将Seed改名为vue,当时的版本是0.6.0

  • 2014年正式对外开放,版本是0.8.0

  • 2015年12月份,vue1.0版本出现

  • 2016年12月1日,vue2.0版本

  • 2020年9月18日,vue3.0版本出现

二、vue环境的搭建

vue环境的搭建有两种方式,第1种方式:使用script标签的方式引入到网页上,这种方式比较使用学习使用,不太使用实际开发,第2种方式:使用vuecli脚手架方式来进行项目搭建,这种方式比较适合实际企业开发用

1、使用script方式引入

具体的实现步骤有如下

  • 在html页面中通过script标签的方式引入vue.js

 <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
  • 在body标签之间定义一个div元素,用来作为vue内容渲染的容器

<div id="app"></div>
  • 创建vue实例

 <script>/*通过new的方式调用构造函数来进行创建vue实例Vue的构造函数的参数是一个对象,该对象中的属性就是vue的选项,这里边的选项都是固定的el:vue挂载目标,这里的值是目标挂载点的选择器data:可以是一个对象,也可以是一函数对象的属性是自定义的*/const vm=new Vue({el:'#app',data:{message:'Hello Vue!~'}})</script>

data选项的后面也可以是一个函数

 /*通过new的方式调用构造函数来进行创建vue实例Vue的构造函数的参数是一个对象,该对象中的属性就是vue的选项,这里边的选项都是固定的el:vue挂载目标,这里的值是目标挂载点的选择器data:可以是一个对象,也可以是一函数对象的属性是自定义的*/const vm=new Vue({el:'#app',data:function(){return{message:'Hello Vue!!!!!!!'}}})
  • 在HTML页面中渲染vue实例的data数据

如果要渲染vue中的data数据的方式很多,但是最常见的是一个插值表达式(双花括号)

 <div id="app">{{message}}</div>

2、使用vue/cli命令行工具安装

  • 首先安装vue/cli

npm i -g @vue/cli
  • 创建vue项目

vue create 项目名称
  • 手动安装

Vue CLI v5.0.8
? Please pick a preset:Default ([Vue 3] babel, eslint)Default ([Vue 2] babel, eslint)
> Manually select features
  • 安装相关依赖包

Vue CLI v5.0.8
? Please pick a preset: Manually select features
? Check the features needed for your project: (Press <space> to select, <a> to toggle all, <i> to invert selection, and
<enter> to proceed)(*) Babel( ) TypeScript( ) Progressive Web App (PWA) Support( ) Router( ) Vuex
>(*) CSS Pre-processors( ) Linter / Formatter( ) Unit Testing( ) E2E Testing
  • 选择vue的版本

Vue CLI v5.0.8
? Please pick a preset: Manually select features
? Check the features needed for your project: Babel, CSS Pre-processors
? Choose a version of Vue.js that you want to start the project with3.x
> 2.x
  • 选择css预处理语言

? Please pick a preset: Manually select features
? Check the features needed for your project: Babel, CSS Pre-processors
? Choose a version of Vue.js that you want to start the project with 2.x
? Pick a CSS pre-processor (PostCSS, Autoprefixer and CSS Modules are supported by default): (Use arrow keys)
> Sass/SCSS (with dart-sass)LessStylus
  • 选择配置文件

Vue CLI v5.0.8
? Please pick a preset: Manually select features
? Check the features needed for your project: Babel, CSS Pre-processors
? Choose a version of Vue.js that you want to start the project with 2.x
? Pick a CSS pre-processor (PostCSS, Autoprefixer and CSS Modules are supported by default): Sass/SCSS (with dart-sass)
? Where do you prefer placing config for Babel, ESLint, etc.? (Use arrow keys)
> In dedicated config filesIn package.json
  • 是否保存预设

Vue CLI v5.0.8
? Please pick a preset: Manually select features
? Check the features needed for your project: Babel, CSS Pre-processors
? Choose a version of Vue.js that you want to start the project with 2.x
? Pick a CSS pre-processor (PostCSS, Autoprefixer and CSS Modules are supported by default): Sass/SCSS (with dart-sass)
? Where do you prefer placing config for Babel, ESLint, etc.? In dedicated config files
? Save this as a preset for future projects? (y/N) N
  • 启动项目

npm run serve
  • 运行项目

3、vue/cli图形界面方式

步骤如下

  • 在终端上输入如下命令打开图形界面方式

vue ui

三、目录结构

1、目录结构的分析

project
|- node_modules:第三方依赖包
|- public:存放静态资源的,这里的静态资源不会被webpack编译|-favicon.ico:icon图标|-index.html:项目index.html文件
|- src:源代码|-assets:静态资源,会被webpack所编译|-components:自定义组件|-App.vue:项目的根组件|-main.js:vue项目的入口文件
|-.gitignore:git上传的忽略文件
|-babel.config.js:babel的配置文件
|-jsconfig.js:js的配置文件
|-package.json:项目配置文件
|-vue.config.js:在文件中可以对webpack的配置进行修改

2、vue项目运行流程

项目启动后,首先运行的是main.js

//导入vue第三依赖包
import Vue from 'vue'
//导入根组件
import App from './App.vue'
//关闭生成提示
Vue.config.productionTip = false
//创建vue实例
//vue的选项
//render:vue2的渲染函数
new Vue({el:'#app',render: h => h(App),
})

注意点:vue2中设置目标挂载点有两种方式

new Vue({el:'#app',render: h => h(App),
})

还有一种方式

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

3、单文件组件

凡是以后缀.vue结尾的都成称为单文件组件,单文件组件有三个部分组成

  • template:该标签之间存放的HTML代码,用来定义结构的

  • script:编写的js代码

  • style:编写的css代码

<template><h1>Hello <span>{{name}}</span></h1>
</template><script>
export default{data:function(){return{name:'Giles'}}
}
</script><style lang="scss">h1{span{color:red}}
</style>

如上代码,如果要向让其有高亮显示和智能提示需要安装vetur插件

四、打包与部署

开发完的vue项目都必须打包并部署到服务器上

部署vue到nginx服务器上的步骤

  • 在vue.config.js文件中需要配置部署路径,具体配置如下

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({transpileDependencies: true,publicPath:'./'    
})
  • 在终端上进行打包,具体打包的命令如下

npm run build
  • 将生成dist目录进行重命名,并且上传到到外网服务器(阿里云)

这里我将目录上传到/opt目录下

  • 在/etc/nginx/config.d/default.confi下的server节点下进行如下配置

location /first {alias /opt/first;index index.html;}
  • 执行如下命令

ps aux|grep nginx
killall -9 nginx
  • 重新启动nginx服务器

/usr/sbin/nginx

五、vue.config.js的配置

如果要进行webpack的配置可以在vue.config.js中进行

const { defineConfig } = require('@vue/cli-service')
module.exports =defineConfig({//部署应用包时的基本 URLpublicPath:'./',//更改打包后的输出目录名称outputDir:'build',//设置放静态资源的目录assetsDir:'static',//指定生成的index.html的输出路径indexPath:'home.html',//设置devServer的选项devServer:{//自动打开页面open:true,host:'127.0.0.1',port:'8888'}
})

六、插值表达式

1、什么叫插值表达式

vue中的内容如果要动态的渲染到页面之上,可以在<template>部分使用插值表达式动态渲染vue中data选项的数据

2、插值表达式语法

{{插值表达式}}

插值表达内容如下

  • 常量

  • 变量

  • 表达式(运算符+操作数)

<template><!--在vue2template模板中的根元素只能是一个,不能是多个--><div><div>姓名:{{name}}</div><div>年龄:{{38}}</div><div>性别:{{gender==1?'男':'女'}}</div><div>爱好:{{hobby.slice(0,1)}}</div><div>求和:{{nums.reduce((prev,cur)=>prev+cur,0)}}</div></div>
</template><script>
export default {data(){return{name:'Giles',gender:1,hobby:['basketball','football','apple'],nums:[10,20,30,59,89,67]}}
}
</script><style></style>
http://www.lryc.cn/news/141449.html

相关文章:

  • 3D点云处理:学习总结(更新整理中)
  • Day45|leetcode 70. 爬楼梯、322. 零钱兑换、279.完全平方数
  • arm:day9
  • 【大模型AIGC系列课程 1-2】创建并部署自己的ChatGPT机器人
  • 启动metastore服务报错
  • c 语言 算法 技巧 之 用移位来代替乘除
  • python爬虫实战零基础(3)——某云音乐
  • 渗透测试漏洞原理之---【XSS 跨站脚本攻击】
  • 【浮点数二分】
  • 基于FPGA的FIR低通滤波器实现(附工程源码),matlab+vivado19.2+simulation
  • c++ qt--事件(第六部分)
  • 嵌入式系统入门实战:探索基本概念和应用领域
  • 关于hive sql进行调优的理解
  • 十大排序算法
  • PIP 常用操作汇总
  • 线性代数的本质笔记(3B1B课程)
  • 快速掌握MQ消息中间件rabbitmq
  • Git push拦截
  • 拼多多anti-token分析
  • 基于微信小程序的中医体质辨识文体活动的设计与实现(Java+spring boot+MySQL)
  • 4.16 TCP 协议有什么缺陷?
  • VMware 修改ip地址 虚拟机静态ip设置 centos动态ip修改为静态ip地址 centos静态ip地址 vmware修改ip地址
  • Deepin添加Ubuntu源
  • Mysql的多表查询和索引
  • Java设计模式之建造者模式
  • H5商城公众号商城系统源码 积分兑换商城系统独立后台
  • 华为OD机试 - 完全数计算(Java 2023 B卷 100分)
  • 每日一学——Vlan配置
  • Pimpl模式
  • Python 密码破解指南:5~9