• axios安装及使用

    网站文档地址:https://www.kancloud.cn/yunye/axios/234845
    1.npm安装 cnpm install axios
    2.// 在main.js里面引入axios
    import Axios from 'axios'
    3.// 将axios 挂载到Vue原型上,这样全局的组件都有该方法了
    Vue.prototype.$https = Axios;
    4.// Axios全局配置基本url(当然也可以不配置),配置后后面就直接写之后的url即可,会默认帮你拼接
    Axios.defaults.baseURL = 'https://www.luffycity.com/api/v1/';
    methods:{
    // 获取课程分类
    get_category_list(){
    // 调用axios的get方法获取数据
    this.$https.get('course_sub/category/list/')
    // 这里注意this指向
    .then((response) => {
    // 如果状态正常,则赋值给category_list
    if (response.data.error_no === 0){
    this.category_list = response.data.data
    }
    })
    .catch(function (error) {
    console.log(error)
    })
    }
    },
    created(){
    // 调用课程分类方法
    this.get_category_list()
    }
  • vuex安装和简单使用

vuex中,有默认的五种基本的对象:

state:存储状态(变量)
getters:对数据获取之前的再次编译,可以理解为state的计算属性。我们在组件中使用 $sotre.getters.fun()
mutations:修改状态,并且是同步的。在组件中使用$store.commit('',params)。这个和我们组件中的自定义事件类似。
actions:异步操作。在组件中使用是$store.dispath('')
modules:store的子模块,为了开发大型项目,方便状态管理而使用的。
1.安装vuex    npm i vuex -S
2.可以在src目录下创建一个vuex文件夹,建一个store,js文件

store.js文件

import Vue from 'vue'
import Vuex from 'vuex' // 引入vuex并且使用vuex
Vue.use(Vuex) // 存储变量count
const state = {
count:0
} // mutations 里面放置的是我们操作state对象属性的方法,还属于同步操作
const mutations = {
// mutations里面的参数,第一个默认为state,接下来的为自定义参数
addCount(state, n) {
return (state.count += n)
},
reduceCount(state, n){
return (state.count -= n)
}
}; // actions是异步操作,有两个不同的参数,一个是context,它是一个和store对象具有相同对象属性的参数
const actions = {
actionAddCount(context, n){
return context.commit('addCount',n)
},
actionReduceCount(context, n){
return context.commit('reduceCount',n)
},
}; // 通过Vuex的方法Store返回
export default new Vuex.Store({
state,
mutations,
actions
})

main.js 引入并挂载store

import Vue from 'vue'
import App from './App'
import router from './router'
import store from './vuex/store' // 引入store Vue.config.productionTip = false /* eslint-disable no-new */
new Vue({
el: '#app',
router,
store, // 记得挂载
components: { App },
template: '<App/>'
})

HelloWorld.vue里面

<template>
<div class="hello">
<!--获取count的值-->
<h2>{{ $store.state.count }}</h2>
<div>同步操作
<div>
<button @click='addClick(1)'>增加</button>
<button @click='reduceClick(1)'>减少</button>
</div>
</div>
<div>异步操作
<div>
<button @click='actionAddClick(1)'>异步增加</button>
<button @click='actionReduceClick(1)'>异步减少</button>
</div>
</div>
</div>
</template> <script>
export default {
name: 'HelloWorld',
data () {
return {}
},
methods:{
addClick(n){
// 通过commit方法调用addCount来进行加减n操作
this.$store.commit('addCount',n);
},
reduceClick(n){
this.$store.commit('reduceCount',n);
},
actionAddClick(n){
// 通过dispatch方法调用actionAddCount,然后actionAddCount再通过commit方法调用addCount进行加减
this.$store.dispatch('actionAddCount',n);
},
actionReduceClick(n){
this.$store.dispatch('actionReduceCount',n);
},
}
}
</script> <!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped> </style>

vuex原理图:

Vue快速学习_第五节的更多相关文章

  1. Vue快速学习_第四节

    获取原生的DOM方式($.refs) 给标签或者组件 添加ref <div ref = 'liu'>test</div> <Home ref = 'home'>&l ...

  2. Vue快速学习_第一节

    之前写CRM都是Django前后端一起写的,在大部分项目中实际上前后端是分离的,因此我们需要学习一个前端框架来进行前端页面的编写,这里选择了Vue进行学习,好了开始学习吧. 1.ES6部分知识点学习 ...

  3. Vue快速学习_第二节

    表单输入绑定(v-model) v-model 指令在表单 <input>.<textarea> 及 <select> 元素上创建双向数据绑定(注意只在表单这几个可 ...

  4. Vue快速学习_第三节

    过滤器 局部过滤器(组件内部使用的过滤器,跟django的很像, filters: {过滤器的名字: {function(val, a,b){}}} 全局过滤器(全局过滤器,只要过滤器一创建,在任何组 ...

  5. 学习HTML 第五节.简单交互 加个按钮

    学习HTML 第五节.简单交互 也许你和我一样,对页面排版的兴趣小于网页交互,那么我们就先略过一些章节,直接先学一下简单交互. 前面点击图片打开链接的网址,已经是最简单的交互方式了,复杂的方式则需要用 ...

  6. 风炫安全WEB安全学习第二十五节课 利用XSS键盘记录

    风炫安全WEB安全学习第二十五节课 利用XSS键盘记录 XSS键盘记录 同源策略是浏览器的一个安全功能,不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源.所以xyz.com下的js脚本采用a ...

  7. android内部培训视频_第五节(1)_OA实战之登录界面

    第五节(1):OA实战之登录界面  一.登录界面布局 1.背景图片 2.文本框 3.checkbox 4.按钮 暂未实现点击切换图片效果 <RelativeLayout xmlns:androi ...

  8. [ExtJS5学习笔记]第五节 使用fontawesome给你的extjs5应用增加字体图标

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/38458411本文作者:sushengmiyan-------------------- ...

  9. Vue(基础四)_总结五种父子组件之间的通信方式

    一.前言 这篇文章主要总结了几种通信方式: 1.方式一:使用props: [ ]和$emit()  (适用于单层通信) 2.方式二:$attrs和$listeners(适用于多层) 3.方式三:中央处 ...

随机推荐

  1. android#ListView的简单用法

    新建项目,并修改项目生产的主文件activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/ap ...

  2. mac编译openJDK8

    买了<深入理解Java虚拟机> 周志明著这本书一直没有看,我们的程序都用JVM在跑,所以学习java必须掌握JVM,才能理解我们对象到底干嘛了.   1.为什么要编译JDK 想要一探JDK ...

  3. android简易跑马灯

    重点:焦点的选择(返回true使得焦点不被选择) MarqueeText.java package com.example.demo02; import android.content.Context ...

  4. 安装部署FastDFS

    安装部署FastDFS 此篇博文是在安装好虚拟机和CentOS7的前提和转自以下几篇博客得来: 1.开启CentOS的网络连接:   1.1.网址:http://blog.csdn.net/white ...

  5. 记:SpringBoot项目莫名出现ClassNotFoundException

    最近某个开发环境的某个应用,隔三差五出现了某某页面找不到,网上百度找了些同类的问题都是说jstl包与默认tomcat里的包冲突,但都感觉和我的问题不是很搭配(因为相同框架的其他项目都可以正常允许) 报 ...

  6. THUSC2016

    补退选 Luogu LOJ BZOJ 比较裸. 建一棵Trie树,记录一下每个节点的\(sum\)表示经过该点的字符串个数,每次暴力插入.删除. 同时每个节点维护一个vector,记录一下这个点的\( ...

  7. # Python3微博爬虫[requests+pyquery+selenium+mongodb]

    目录 Python3微博爬虫[requests+pyquery+selenium+mongodb] 主要技术 站点分析 程序流程图 编程实现 数据库选择 代理IP测试 模拟登录 获取用户详细信息 获取 ...

  8. Web前端开发JavaScript基础

    JavaScript 一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型,它的解释器被称为JavaScript引擎,是浏览器的一部分,并且是被广泛用于客户端的脚本语言,JavaS ...

  9. 《深入实践C++模板编程》之四——特例

    1. 所谓模板特例,是针对符合某种条件的模板参数值集合另外声明的模板实现变体. template<typename T> class my_vector; template<> ...

  10. C手写一个多线程,供java调用

    package com.tigger; public class MyThread { static { //装载库,保证jvm在启动的时候就会装载 System.loadLibrary(" ...