前言:
现在看官们对“vueajaxtemplate”可能比较关注,兄弟们都想要学习一些“vueajaxtemplate”的相关文章。那么小编也在网上网罗了一些对于“vueajaxtemplate””的相关知识,希望我们能喜欢,姐妹们一起来了解一下吧!Vue 技术栈(全家桶)
尚硅谷前端研究院
第 1 章:Vue 核心
Vue 简介官网英文官网: 中文官网: 介绍与描述动态构建用户界面的渐进式 JavaScript 框架作者: 尤雨溪Vue 的特点遵循 MVVM 模式编码简洁, 体积小, 运行效率高, 适合移动/PC 端开发它本身只关注UI, 也可以引入其它第三方库开发项目与其它 JS 框架的关联借鉴Angular 的模板和数据绑定技术借鉴React 的组件化和虚拟DOM 技术Vue 周边库vue-cli: vue 脚手架vue-resourceaxiosvue-router: 路由vuex: 状态管理element-ui: 基于vue 的UI 组件库(PC 端)
……
初识 Vue模板语法效果模板的理解
html 中包含了一些JS 语法代码,语法分为两种,分别为:
插值语法(双大括号表达式)指令(以v-开头)插值语法功能: 用于解析标签体内容语法: {{xxx}} ,xxxx 会作为js 表达式解析指令语法功能: 解析标签属性、解析标签体内容、绑定事件举例:v-bind:href = 'xxxx' ,xxxx 会作为js 表达式被解析说明:Vue 中有有很多的指令,此处只是用v-bind 举个例子数据绑定效果单向数据绑定语法:v-bind:href ="xxx" 或简写为 :href特点:数据只能从data 流向页面双向数据绑定语法:v-mode:value="xxx" 或简写为 v-model="xxx"特点:数据不仅能从data 流向页面,还能从页面流向 dataMVVM 模型M:模型(Model) :对应data 中的数据V:视图(View) :模板VM:视图模型(ViewModel) : Vue 实例对象事件处理效果绑定监听v-on:xxx="fun"@xxx="fun"@xxx="fun(参数)"默认事件形参: event隐含属性对象: $event事件修饰符.prevent : 阻止事件的默认行为 event.preventDefault().stop : 停止事件冒泡 event.stopPropagation()按键修饰符keycode : 操作的是某个keycode 值得键.keyName : 操作的某个按键名的键(少部分)计算属性与监视效果计算属性-computed要显示的数据不存在,要通过计算得来。在computed 对象中定义计算属性。在页面中使用{{方法名}}来显示计算的结果。监视属性-watch通过通过vm 对象的$watch()或watch 配置来监视指定的属性当属性变化时, 回调函数自动调用, 在函数内部进行计算class 与 style 绑定理解在应用界面中, 某个(些)元素的样式是变化的class/style 绑定就是专门用来实现动态样式效果的技术class 绑定:class='xxx'表达式是字符串: 'classA'表达式是对象: {classA:isA, classB: isB}表达式是数组: ['classA', 'classB']style 绑定:style="{ color: activeColor, fontSize: fontSize + 'px' }"其中activeColor/fontSize 是data 属性条件渲染条件渲染指令v-if 与v-elsev-show比较v-if 与v-show如果需要频繁切换 v-show 较好当条件不成立时, v-if 的所有子节点不会解析(项目中使用)列表渲染效果列表显示指令
遍历数组: v-for / index 遍历对象: v-for / key
收集表单数据过滤器效果理解过滤器功能: 对要显示的数据进行特定格式化后再显示注意: 并没有改变原本的数据, 是产生新的对应的数据内置指令与自定义指令常用内置指令v-text : 更新元素的 textContentv-html : 更新元素的 innerHTMLv-if : 如果为true, 当前标签才会输出到页面v-else: 如果为false, 当前标签才会输出到页面v-show : 通过控制display 样式来控制显示/隐藏v-for : 遍历数组/对象v-on : 绑定事件监听, 一般简写为@v-bind : 绑定解析表达式, 可以省略v-bindv-model : 双向数据绑定v-cloak : 防止闪现, 与css 配合: [v-cloak] { display: none }自定义指令注册全局指令
Vue.directive('my-directive', function(el, binding){ el.innerHTML = binding.value.toupperCase()
})
注册局部指令
directives : {
'my-directive' : { bind (el, binding) {
el.innerHTML = binding.value.toupperCase()
}
}
}
1) 使用指令
v-my-directive='xxx'
Vue 实例生命周期效果生命周期流程图vue 生命周期分析初始化显示beforeCreate()created()beforeMount()mounted()更新状态: this.xxx = valuebeforeUpdate()updated()销毁vue 实例: vm.$destory()beforeDestory()destoryed()常用的生命周期方法mounted(): 发送ajax 请求, 启动定时器等异步任务beforeDestory(): 做收尾工作, 如: 清除定时器第 2 章:Vue 组件化编程模块与组件、模块化与组件化模块理解: 向外提供特定功能的 js 程序, 一般就是一个js 文件为什么: js 文件很多很复杂作用: 复用js, 简化js 的编写, 提高js 运行效率组件理解: 用来实现局部(特定)功能效果的代码集合(html/css/js/image…..)为什么: 一个界面的功能很复杂作用: 复用编码, 简化项目编码, 提高运行效率模块化
当应用中的js 都以模块来编写的, 那这个应用就是一个模块化的应用。
组件化
当应用中的功能都是多组件的方式来编写的, 那这个应用就是一个组件化的应用,。
非单文件组件模板编写没有提示没有构建过程, 无法将ES6 转换成ES5不支持组件的CSS真正开发中几乎不用单文件组件一个.vue 文件的组成(3 个部分)模板页面
<template> 页面模板
</template>
JS 模块对象
<script> export default {
data() {return {}}, methods: {},
computed: {}, components: {}
}
</script>
样式
<style> 样式定义
</style>
基本使用引入组件映射成标签使用组件标签第 3 章:使用 Vue 脚手架初始化脚手架说明Vue 脚手架是Vue 官方提供的标准化开发工具(开发平台)。最新的版本是 4.x。文档: 。具体步骤
第一步(仅第一次执行):全局安装@vue/cli。
npm install -g @vue/cli
第二步:切换到你要创建项目的目录,然后使用命令创建项目
vue create xxxx 第三步:启动项目
npm run serve
备注:
1.
如出现下载缓慢请配置 npm 淘宝镜像:
npm
config
set
registry
2. Vue 脚手架隐藏了所有webpack 相关的配置,若想查看具体的webpakc 配置, 请执行:vue inspect > output.js
模板项目的结构├── node_modules
├── public
│ ├── favicon.ico: 页签图标
│ └── index.html: 主页面
├── src
│ ├── assets: 存放静态资源
│ │ └── logo.png
│ │── component: 存放组件
│ │ └── HelloWorld.vue
│ │── App.vue: 汇总所有组件
│ │── main.js: 入口文件
├── .gitignore: git 版本管制忽略的配置
├── babel.config.js: babel 的配置文件
├── package.json: 应用包配置文件
├── README.md: 应用描述文件
├── package-lock.json:包版本控制文件
ref 与 props
ref
作用:用于给节点打标识读取方式:this.$refs.xxxxxxprops作用:用于父组件给子组件传递数据读取方式一: 只指定名称
props: ['name', 'age', 'setName']
读取方式二: 指定名称和类型
props: {
name: String, age: Number,
setNmae: Function
}
读取方式三: 指定名称/类型/必要性/默认值
props: {
name: {type: String, required: true, default:xxx},
}
混入Vue 插件是一个包含install 方法的对象通过install 方法给Vue 或Vue 实例添加方法, 定义全局指令等插件Vue 插件是一个包含install 方法的对象通过install 方法给Vue 或Vue 实例添加方法, 定义全局指令等Todo-list 案例组件化编码流程(通用)实现静态组件:抽取组件,使用组件实现静态页面效果展示动态数据:数据的类型、名称是什么?数据保存在哪个组件? 3.交互——从绑定事件监听开始Vue 中的自定义事件绑定事件监听
<Header @addTodo="addTodo"/>
或者
<Header ref="header"/> this.$refs.header.$on('addTodo', this.addTodo)
触发事件
this.$emit('addTodo', todo)
全局事件总线理解Vue 原型对象上包含事件处理的方法$on(eventName, listener): 绑定自定义事件监听$emit(eventName, data): 分发自定义事件$off(eventName): 解绑自定义事件监听$once(eventName, listener): 绑定事件监听, 但只能处理一次所有组件实例对象的原型对象的原型对象就是Vue 的原型对象所有组件对象都能看到Vue 原型对象上的属性和方法Vue.prototype.$bus = new Vue(), 所有的组件对象都能看到$bus 这个属性对象全局事件总线包含事件处理相关方法的对象(只有一个)所有的组件都可以得到指定事件总线对象
new Vue({
beforeCreate () { // 尽量早的执行挂载全局事件总线对象的操作
Vue.prototype.$globalEventBus = this
},
}).$mount('#root')
绑定事件
this.$globalEventBus.$on('deleteTodo', this.deleteTodo)
分发事件
this.$globalEventBus.$emit('deleteTodo', this.index)
解绑事件
this.$globalEventBus.$off('deleteTodo')
消息订阅与发布理解这种方式的思想与全局事件总线很相似它包含以下操作:订阅消息 --对应绑定事件监听发布消息 --分发事件取消消息订阅 --解绑事件监听需要引入一个消息订阅与发布的第三方实现库: PubSubJS使用PubSubJS在线文档: 下载: npm install -S pubsub-js相关语法import PubSub from 'pubsub-js' // 引 入PubSub.subscribe(‘msgName’, functon(msgName, data){ })PubSub.publish(‘msgName’, data): 发布消息, 触发订阅的回调函数调用PubSub.unsubscribe(token): 取消消息的订阅过度与动画效果vue 动画的理解操作css 的trasition 或animationvue 会给目标元素添加/移除特定的class过渡的相关类名:xxx-enter-active: 指定显示的transitionxxx-leave-active: 指定隐藏的transitionxxx-enter/xxx-leave-to: 指定隐藏时的样式基本过渡动画的编码在目标元素外包裹<transition name="xxx">定义class 样式指定过渡样式: transition指定隐藏时的样式: opacity/其它第 4 章:Vue 中的 ajax解决开发环境 Ajax 跨域问题
使用代理服务器
github 用户搜索案例效果接口地址
vue 项目中常用的 2 个 Ajax 库axios
通用的Ajax 请求库, 官方推荐,使用广泛
vue-resource
vue 插件库, vue1.x 使用广泛,官方已不维护。
slot 插槽效果
效果一(不使用插槽):
效果二(默认插槽):
效果三(具名插槽):
效果三(作用域插槽):
理解
父组件向子组件传递带数据的标签,当一个组件有不确定的结构时, 就需要使用slot 技术,注意:插槽内容是在父组件中编译后, 再传递给子组件的。
分类默认插槽命名插槽作用域插槽第 5 章:vuex理解 vuexvuex 是什么概念:专门在Vue 中实现集中式状态(数据)管理的一个Vue 插件,对vue 应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信。Github 地址: 什么时候使用 Vuex多个组件依赖于同一状态来自不同组件的行为需要变更同一状态案例Vuex 工作原理图vuex 核心概念和 APIstatevuex 管理的状态对象它应该是唯一的示例代码:actions值为一个对象,包含多个响应用户动作的回调函数通过commit( )来触发mutation 中函数的调用, 间接更新state如何触发actions 中的回调?
在组件中使用: $store.dispatch('对应的action 回调名') 触发
可以包含异步代码(定时器, ajax 等等)示例代码:mutations值是一个对象,包含多个直接更新state 的方法谁能调用mutations 中的方法?如何调用?
在action 中使用:commit('对应的 mutations 方法名') 触发
mutations 中方法的特点:不能写异步代码、只能单纯的操作state示例代码:getters值为一个对象,包含多个用于返回数据的函数如何使用?—— $store.getters.xxx示例代码:modules包含多个module一个module 是一个store 的配置对象与一个组件(包含有共享数据)对应第 6 章:vue-router相关理解vue-router 的理解
vue 的一个插件库,专门用来实现SPA 应用
对SPA 应用的理解单页Web 应用(single page web application,SPA)。整个应用只有一个完整的页面。点击页面中的导航链接不会刷新页面,只会做页面的局部更新。数据需要通过ajax 请求获取。路由的理解什么是路由?一个路由就是一组映射关系(key - value)key 为路径, value 可能是function 或component路由分类后端路由:理解:value 是function, 用于处理客户端提交的请求。工作过程:服务器接收到一个请求时, 根据请求路径找到匹配的函数来处理请求, 返回响应数据。前端路由:理解:value 是component,用于展示页面内容。工作过程:当浏览器的路径改变时, 对应的组件就会显示。基本路由效果总结: 编写使用路由的 3 步定义路由组件注册路由使用路由嵌套(多级)路由路由传参编程式路由导航相关 API:this.$router.push(path): 相当于点击路由链接(可以返回到当前路由界面)this.$router.replace(path): 用新路由替换当前路由(不可以返回到当前路由界面)this.$router.back(): 请求(返回)上一个记录路由this.$router.go(-1): 请求(返回)上一个记录路由this.$router.go(1): 请求下一个记录路由第 7 章:Vue UI 组件库移动端常用UI 组件库Vant Cube UI Mint UI PC 端常用UI 组件库Element UI IView UI
标签: #vueajaxtemplate