Vue--- Vue(Pubsub + Ajax) 数据交互
案例知识点
- 兄弟组件儿的通信 使用了Pubsub 订阅与发布
- ajax数据请求 获取前 获取中 获取后 获取为空 获取异常
- 获取成功后显示数据给到 原先定义号的 jsonData users
vue Search案例 消息订阅pubsub与ajax
pubsub消息订阅组件,便于兄弟组件间调用
npm install --save pubsub-js

App.vue
<template>
<div id="app">
<div class="container">
<Search/>
<users-main/>
</div>
</div>
</template> <script>
import Search from './components/Search.vue'
import Main from './components/Main.vue'
export default{
components:{
Search,
// 内部定义的关键词名称 不可以使用 所以赋值一个名字
UsersMain:Main }
};
</script> <style type="stylus"> </style>Main.vue
// 由于请求状态在Main中,ajax写在main中以便同步更新4个状态。 写在search中不便更新状态。
<template>
<div>
<!-- 搜索我有四种状态 -->
<!-- 1.搜索之前 -->
<h2 v-if="firstView">输入用户名搜索</h2>
<!-- 2.搜索中.... -->
<h2 v-if="loading">GitData...</h2>
<!-- 4.没有搜索到 -->
<h2 v-if="overNull">该关键字没有搜索到Data...</h2>
<!-- 3.搜索失败error -->
<h2 v-if="errorMsg">{{errorMsg}}</h2>
<div v-else class="row" v-for="(user,index) in users" :key="index" :index="index">
<div class="card">
<a :href="user.url" target="_blank">
<img :src="user.avatar_url" style='width: 100px'/>
</a>
<p class="card-text">{{user.name}}</p>
</div>
</div>
</div>
</template> <script type="text/ecmascript-6">
import PubSub from 'pubsub-js'
import axios from 'axios'
export default{
data(){
return {
firstView: true,
loading:false,
overNull:false,
errorMsg: '',
users:null
// [
// {url:'',avatar_url:'',name:''},
// ] }
},
mounted(){
// 是否在此发ajax消息 是点击search后
// 订阅搜索的消息
PubSub.subscribe('search',(msg,searchName)=>{
const url = `https://api.github.com/search/users?q=${searchName}`
// 更新失败(请求中)
this.firstView = false
this.loading = true
this.overNull = false
alert('请求中')
// 发送ajax请求
axios.get(url).then(response=> {
// 获取数据 data
const result = response.data
// data中的items 里面有图片的路径 名称
const users = result.items.map(item=>({
url:item.html_url,
avatar_url:item.avatar_url,
name: item.login
}))
if(users.length !== 0){
console.log(users)
} // 成功更新状态(成功)
this.loading = false
this.users = users if(users.length == 0){
this.overNull = true
}
// 失败更新状态(失败)
}).catch(error=>{
this.loading = false
this.errorMsg = '请求失败'
}) })
} };
</script> <style type="stylus" rel="stylesheet/stylus"> .card {
float: left;
width: 33.333%;
padding: .75rem;
margin-bottom: 2rem;
border: 1px solid #efefef;
text-align: center;
} .card > img {
margin-bottom: .75rem;
border-radius: 100px;
} .card-text {
font-size: 85%;
} </style>Search.vue
<template>
<div>
<section class="jumbotron">
<h3 class="jumbotron-heading">Search Github Users</h3>
<div>
<input type="text" placeholder="enter the name you search" v-model="searchName"/>
<button @click="search">Search</button>
</div>
</section>
</div>
</template> <script type="text/ecmascript-6">
import PubSub from 'pubsub-js'
export default{
data(){
return {
searchName:''
}
},
methods:{
search(){
const searchName = this.searchName.trim()
if(searchName){
// 发布搜索的消息
PubSub.publish('search',searchName)
}
}
} };
</script> <style type="stylus" rel="stylesheet/stylus"> </style>
Vue--- Vue(Pubsub + Ajax) 数据交互的更多相关文章
- Atitit vue.js 把ajax数据 绑定到form表单
Atitit vue.js 把ajax数据 绑定到form表单 1.1. 使用场景:主要应用在编辑与提交场合..1 1.2. 绑定数据到form控件,可以使用jquery,不过vue.js更加简单1 ...
- 弹出层和ajax数据交互
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs& ...
- Struts2与Ajax数据交互
写在前面: ajax请求在项目中常常使用,今天就平时掌握的总结一下,关于使用ajax请求到Struts2中的action时,前台页面与后台action之间的数据传递交互问题. 这里我主要记录下自己所掌 ...
- ajax数据交互
目录 一.ORM查询优化 1-1. only与defer 1-2. select_related与prefatch_related 二.MTV与MVC模型 三.choices参数 四.AJAX 4-1 ...
- django建立管理系统之五----单页ajax数据交互
ajax数据提交: 需求: 1. 点击ajax方式提交后数据提交到后台数据库,并且在前台实现数据更新 a.可以用刷新页面来实现数据页面的更新 对应的html,实现局部刷新(可以用刷新页面实现,例如 $ ...
- vue.js 三(数据交互)isomorphic-fetch
至于fetch的介绍,在这里就不多说了,官方和网络上的说明不少 之前使用jquery的Ajax朋友,可以尝试一下使用一下这个新的api 推荐使用isomorphic-fetch,兼容Node.js和浏 ...
- ajax数据交互(arcgis server)
通过ajax来调用服务器map数据,来实现搜索功能. 效果: 1.我要搜索下中国移动的地理信息: 2.会搜出17条消息,然后把他们分页显示,一页6条: 3.每一页的6天数据,会在map生成一个6条ma ...
- jq ajax数据交互
get 与 post 的区别 了解和使用 get和post是HTTP与服务器交互的方式, 说到方式,其实总共有四种:put,delete,post,get. 他们的作用分别是对服务器资源的增,删,改, ...
- jSon和Ajax登录功能,ajax数据交互案例
ajax实例,检测用户与注册 检测用户名是否被占用: 在用户填写完用户名之后,ajax会异步向服务器发送请求,判断用户名是否存在 首先写好静态页面: index.html <!DOCTYPE h ...
- EChats+Ajax之柱状图的数据交互
原文链接:https://blog.csdn.net/qq_37936542/article/details/79723710 一:下载 echarts.min.js 选择完整版进行下载,精简版和常用 ...
随机推荐
- mysql应用学习-windows(64位)安装和配置mysql(5.6.20)
下载安装包MySQL Installer 下载地址1:http://dev.mysql.com/downloads/windows/installer/ 说明:官网当前版本 5.6.22:虽然只有32 ...
- 【U1结业机试题】新闻内容管理系统:解析XML文件读取Html模版生成网页文件
一.作业要求: 1.在xml文件中创建新闻节点news,包含标题.作者.日期.正文等信息 2.创建HTML模板文件 3.读取xml中所有新闻信息,并使用新闻信息替换模板文件中占位符,从而为每一条新闻生 ...
- 【学习笔记】关于DOM4J:使用DOM4J解析XML文档
一.概述 DOM4J是一个易用的.开源的库,用于XML.XPath和XSLT中.采用了Java集合框架并完全支持DOM.SAX.和JAXP. DOM4J最大的特色是使用大量的接口,主要接口都在org. ...
- 纯CSS的三角符号
项目中经常用到三角形,现在给大家讲下用纯CSS写的下三角实心图形 .triangle{ border-width: 5px 4px 0 4px; border-color: #454A7B trans ...
- Nodejs介绍及npm工具使用
一.Nodejs介绍 Nodejs英文网:https://nodejs.org/en/ Nodejs中文网:http://nodejs.cn/ Node.js 是一个基于 Chrome V8 引擎的 ...
- 1729 单词查找树 2000年NOI全国竞赛
1729 单词查找树 2000年NOI全国竞赛 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 在进行文法分析的 ...
- vue使用qrcode生成二维码,可以自定义大小
1,qrcanvas-vue插件,https://gera2ld.github.io/qrcanvas-vue/#logo.只支持像素大小的二维码 2,qrcode支持移动端自定义大小二维码 &quo ...
- Aligning Plots in a Column作图列对齐
Plot[Sin[x], {x, 0, Pi}] Plot[10000 Sin[x], {x, 0, Pi}] 直接作图左边无法对齐,影响图的美观.可以使用左边界空格实现列对齐,代码如下: optio ...
- Linux CentOS如何汉化系统
su root切换为root用户 写入环境变量 echo "export LANG="zh_CN.UTF8"">>/etc/profile sour ...
- 在crontab中执行脚本重要事项
crontab不能成功执行shell脚本的可能原因 crond进程不存在,该进程是crontab的守护进程,它必须存在才能让crontab正常使用: 系统时间不对: 环境变量的问题:crontab执行 ...