一篇超完整的Vue新手入门指导教程


Posted in Vue.js onNovember 18, 2020

前言

新建项目近些年前端开发快速发展,现在学习前端已经不像以前那样仅仅学习一个语法就可以了,它已经是一门编程技术了,它们有自己独立的类似Main函数的入口,有像MVC一样规范好的层次结构,有自己的开发工具可以发布打包程序,甚至还可以独立连接数据库,当然了,优点与缺点共存,不能向其他语言那样断点调试导致了,它的脉络更难被捕捉,犹如远古时代的代码开发一样,但它还是已经可以称为一门编程技术了,所以学习一门前端开发,已经是一件非常有意义的事儿了。

首先安装Nodejs,然后我们一起学习使用Vue。

Vue是一个前端框架,安装了Nodejs后,可以使用Npm命令直接下载vue。

打开cmd窗口,依次输入如下命令:

npm i vue -g
npm i vue-cli -g

注:输入【npm i vue -g】下载vue时,尽量使用-g,因为vue的文件中有一些文件是可以vue开头的命令行的,因为-g是下载到环境变量配置的Path地址,所以如果下载到这里,那么vue开头的命令就可以在cmd窗口中直接使用了,不然还需要重新配置环境变量,添加当前下载目录。

下载完Vue后,我们新建一个文件夹,然后打开CMD跳转该目录,如【cd/d F:\Nodejs2】,然后使用vue开头的命令创建一个项目,在cmd窗口输入命令如下:

vue init webpack my-project

输入完命令后,会提示我们配置项目信息,可以一直回车使用默认配置,然后等待项目创建完成。

注:输入vue init webpack my-project后,不要切换窗口,一直回车,就可以创建成了,如果切换窗口了,切换回当前cmd窗口后,回车有时候无法直接输入,需要操作下才能输入,比如先按一下个上下左右键。

项目创建完成后,得到如下界面内容。

一篇超完整的Vue新手入门指导教程

项目创建完成,我们会在目录下多了一个文件夹—my-project。

一篇超完整的Vue新手入门指导教程

然后我们在通过CMD命令在跳转到项目目录【cd/d F:\Nodejs2\my-project】,然后运行npm install,进行初始化。

npm install

最后,我们再输入命令npm run dev,得到窗体如下:

一篇超完整的Vue新手入门指导教程

然后打开浏览器,输入http://localhost:8080,vue项目运行成功,如下图:

一篇超完整的Vue新手入门指导教程

注:vue自带了一个类似server.js的配置,所以运行npm run dev命令后,会启动一个服务器。

学习项目

刚刚安装的VSCode需要禁用JS-CS-HTML Formatter插件,不然保存代码时会自动格式化了,然后html代码全乱了通过VisualStudioCode将新建的项目打开。

禁用方法:ctrl+shift+X调出扩展,搜索JS-CS-HTML Formatter ,然后禁用,然后重启。

新建项目结构如下图:

一篇超完整的Vue新手入门指导教程

结构描述如下表:

文件夹/文件 描述
build 项目构建(webpack)相关代码
config 配置目录,包括端口号等。我们初学可以使用默认的。
node_modules npm 加载的项目依赖模块
src 这里是我们要开发的目录,基本上要做的事情都在这个目录里。里面包含了几个目录及文件。
static 静态资源目录,如图片、字体等。
test 初始测试目录,可删除
.其他文件 这些是一些配置文件,包括语法配置,git配置等。
index.html 这是一个模板文件,同时又是Main.js的展示页面,也可以理解为Index.html的ViewModel是Main.js,Main.js是项目启动的入口。项目启动时Main.js会读取该页面,然后把当前显示的vue文件渲染进该页面。类似于MVC中的layout.cshtml文件的作用。
package.json 项目配置文件。
README.md 项目的说明文档,markdown 格式

src核心

src是我们代码编写的核心文件,其内容如下:

assets: 放置一些图片,如logo等。

components: 目录里面放了一个组件文件,可以不用。

App.vue: 项目入口文件,我们也可以直接将组件写这里,而不使用components 目录。

main.js: 项目的核心文件。

代码详解

Main.js是项目的入口,类似其他语言的Main函数,代码如下:Main.js

import Vue from 'vue'//引入vue.js文件
import App from './App'//引入当前目录下的App.vue文件,【./】指当前目录,【.vue】被隐藏了
import router from './router'//引入当前目录下router文件夹下的Index.js文件

Vue.config.productionTip = false//屏蔽调试时的一些console日志内容

/* eslint-disable no-new */
new Vue({
 el: '#app',
 router,//指定路由的js对象
 components: { App },//加载上方导入到组件。
 template: '<App/>'//选择一个组件去替换index.html 中的<div id="app"></div>。这里使用我们components导入的App组件,相当于指定初始化时的显示组件,Vue组件注册后可以使用<tagName></tagName>的模式来使用组件。
})

import

import类似其他语言的引入命名空间或引入包,这里主要是用于引入js文件和vue文件。

如果引入的是js文件,则鼠标放到引用上,会显示具体引用路径,如下图:

一篇超完整的Vue新手入门指导教程

new Vue

new Vue这一段是创建一个js的Vue对象,该对象的构造函数,接受一个对象,这里传了一个匿名对象,我们可以看到,new Vue后的圆括号【(】里,跟了一对大括号【{】,然后这个对象里,有几个属性,需要初始化。

el:估计是element的缩写,表示Vue绑定的元素。

router:router是我们上面引入的router文件夹下的Index.js文件,打开文件,代码如下:

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'

Vue.use(Router)

export default new Router({
 routes: [
 {
 path: '/',
 name: 'HelloWorld',
 component: HelloWorld
 }
 ]
})

可以看到,代码中开放了一个默认的Router类型的对象,这个对象是vue-router中定义的,用于定义页面跳转路由,这里定义了路径HelloWorld对应导入/components/HelloWorld.vue文件。

ps:export类似于其他语言的public,就是公开该js文件的某个对象或函数,export default就是默认公开的那一个,这样其他js文件使用import导入该js文件时,就可以省略指定对象这几个代码,这种是一个很原始的程序设计风格,大家还需要适应。

App.Vue

App.Vue是Main.js默认加载的模块,其代码如下:

<template>
 <div id="app">
 <h2>Kiba518</h2>
 <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>

这里主要是用于配置路由视图—— ,其他的样式我们可以暂时忽略。

可以看到我们把路由视图(router-view)配置在了一个div中,并且还放在了一个H2下面,这样,我们的这个H2标签就永远会在路由视图上面了。

运行项目

一篇超完整的Vue新手入门指导教程

我们对App.Vue和HelloWorld.vue进行了简单修改,然后不用重启,不用编译,只需要重新切换回刚刚的那个网页——http://localhost:8080。

如上图所示,我们得到了修改页面。

到此Vue的基本使用已经介绍完了。

总结

到此这篇关于Vue入门指导的文章就介绍到这了,更多相关Vue入门指导内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
手写Vue源码之数据劫持示例详解
Jan 04 Vue.js
vue watch监控对象的简单方法示例
Jan 07 Vue.js
Vue仿Bibibili首页的问题
Jan 21 Vue.js
vue首次渲染全过程
Apr 21 Vue.js
vue项目两种方式实现竖向表格的思路分析
Apr 28 Vue.js
原生JS封装vue Tab切换效果
Apr 28 Vue.js
vue如何批量引入组件、注册和使用详解
May 12 Vue.js
Vue实现导入Excel功能步骤详解
Jul 03 Vue.js
vue+echarts实现多条折线图
Mar 21 Vue.js
vue项目如何打包之项目打包优化(让打包的js文件变小)
Apr 30 Vue.js
vue @ ~ 相对路径 路径别名设置方式
Jun 05 Vue.js
vue如何在data中引入图片的正确路径
Jun 05 Vue.js
vue3.0实现点击切换验证码(组件)及校验
Nov 18 #Vue.js
在Vue中使用Echarts可视化库的完整步骤记录
Nov 18 #Vue.js
详解vue实现坐标拾取器功能示例
Nov 18 #Vue.js
Vue如何循环提取对象数组中的值
Nov 18 #Vue.js
vue在图片上传的时候压缩图片
Nov 18 #Vue.js
Vue +WebSocket + WaveSurferJS 实现H5聊天对话交互的实例
Nov 18 #Vue.js
springboot+vue实现文件上传下载
Nov 17 #Vue.js
You might like
php微信开发之批量生成带参数的二维码
2016/06/26 PHP
Laravel validate error处理,ajax,json示例
2019/10/25 PHP
javascript 限制输入和粘贴(IE,firefox测试通过)
2008/11/14 Javascript
JavaScript 保存数组到Cookie的代码
2010/04/14 Javascript
基于Jquery的标签智能验证实现代码
2010/12/27 Javascript
js indexOf()定义和用法
2012/10/21 Javascript
JS实现淘宝幻灯片效果的实现方法
2013/03/22 Javascript
JS中引用百度地图并将百度地图的logo和信息去掉
2013/09/29 Javascript
jQuery实现动态表单验证时文本框抖动效果完整实例
2015/08/21 Javascript
jQuery学习笔记之Ajax用法实例详解
2015/12/01 Javascript
基于JavaScript实现简单的随机抽奖小程序
2016/01/05 Javascript
基于jQuery实现动态搜索显示功能
2016/05/05 Javascript
轻松实现js选项卡切换效果
2016/09/24 Javascript
Vue+Flask实现简单的登录验证跳转的示例代码
2018/01/13 Javascript
解决Js先触发失去焦点事件再执行点击事件的问题
2018/08/30 Javascript
JS实现处理时间,年月日,星期的公共方法示例
2019/05/31 Javascript
[00:43]FTP典藏礼包 DOTA2三大英雄霸气新套装
2014/03/21 DOTA
Python之eval()函数危险性浅析
2014/07/03 Python
浅谈python中截取字符函数strip,lstrip,rstrip
2015/07/17 Python
python3+PyQt5实现文档打印功能
2018/04/24 Python
Django框架使用富文本编辑器Uedit的方法分析
2018/07/31 Python
Windows下安装Scrapy
2018/10/17 Python
解决PyCharm控制台输出乱码的问题
2019/01/16 Python
Python+pyplot绘制带文本标注的柱状图方法
2019/07/08 Python
Python列表切片常用操作实例解析
2020/03/10 Python
Python如何给函数库增加日志功能
2020/08/04 Python
python解包用法详解
2021/02/17 Python
CSS3 特效范例整理
2011/08/22 HTML / CSS
阿迪达斯英国官方网站:adidas英国
2019/08/13 全球购物
银行优秀员工事迹
2014/02/06 职场文书
加入学生会演讲稿
2014/04/24 职场文书
煤矿安全生产标语
2014/06/06 职场文书
县长群众路线对照检查材料思想汇报
2014/10/02 职场文书
事业单位岗位说明书
2015/10/08 职场文书
SpringAop日志找不到方法的处理
2021/06/21 Java/Android
java中如何截取字符串最后一位
2022/07/07 Java/Android