数据获取

framework7自带request方法 ,

var app = new Framework7({
...
});
app.request(parameters) 或者 Framework7.request(parameters)
两者都一样

一个完整的请求可能长下面这样

app.request.get(url, data, success, error, dataType)

app.request.get("res.xxx", {name:'xxx'}, function(data){
console.log(data);
}, function(){
console.log("获取数据失败");
}, 'json');
并不推荐这种方式 推荐下面这种,清晰明了
app.request.get({
url:"res.xxx",
data:{name:"xxx"},  
success:function(data){
console.log(data)
},
error:function(){
console.log("数据获取失败")
},
dataType:"json"
});

获取数据之后就要传数据,有几种方法

通过路由

framework7给路由提供一个async方法

routes:[
{
path: '/about/', //componentUrl:"./pages/about.html",
async: function (routeTo, routeFrom, resolve, reject) {
app.request.get('res.xxx', function (data) {
resolve(
{
componentUrl:"./pages/about.html"
},                 
{
context: { //传数据
users: data,
},
}
);
});
}
}
]
注意,除非你在 async 方法中执行了 resolve 或 reject ,否则路由请求将会中断!

about.html 是个 template组件,所以routers  长这样

{
path:'xxx',
componentUrl:"xxx.html"
}

如果是个完整的html

{
path:'xxx',
url:"xxx.html"
}

还有一些别的参数,参考官方文档

async方法可以用在 当用户未登录时拦截跳转,然后导航到登录页

在about.html页我们可以取到这个users

<template>
<div class="page">
about
<h1>{{Name}}</h1>
</div>
</template>
<style></style>
<script>
return{
data:function(){ //数据相关
let name=this.$route.context.users;
return { //返回要绑定的数据
Name:name
}
}
}
</script>

还可以放在data里

return{
data:function(){
app.request.get({
url:"xxx",
...
success:function(data){
var name=data.name;
}
});
return {
Name:name
}
}
}

看看return

return{
data:function(){
...
},
methods:{
showHello:function(){
app.dialog.alert("Hello");
}
},
on:{ //on里面的函数,在不同的生命周期执行
pageMounted:function(e){}, pageInit:function(e){
this.showHello();
}, pageBeforeIn:function(e){}, pageAfterIn:function(e){}
}
}

这两种方法会有点问题,当你获取数据很慢时,会发现你能在pageInit里打印出data,但没法绑到页面上,原因在于取到data时 ,页面已经渲染完成,不会重新渲染,直到3.31版加了个$setState方法,

return{
data:function(){
return {
Name:""
}
},
methods:{
getData:function(func){
app.request.get({
url:"res.xxx",
...
success:function(data){
func(data);
}
});
}
},
on:{
pageInit:function(){
let self=this;
self.getDate(function(data){
self.$setState({
Name:data.name
});
});
}
}
}

这样就不用担心dom渲染完而数据还没取到

$setState是用VDOM实现的。我理解的是,页面渲染时生成一个dom树,执行$setState时,会在内存中生成一个dom树,然后对两个dom进行对比,用内存中变化的节点替换浏览器中原来的节点,然后让浏览器重新渲染这个节点。

framework7 入门(数据获取和传递)的更多相关文章

  1. Entity Framework7 入门之全功能.NET版本下使用EF7(含源码)另附数据迁移常见错误处理

    Entity Framework7 入门之全功能.NET(Console, WinForms, WPF等)使用EF7 昨天,我们介绍了EF的新特性和开发计划,如果你还不了解,请移步 Entity Fr ...

  2. (二)cordova+framework7入门——笑笑APP

    [前言] framework7确实做的很赞,但是一直各种原因没有做什么app, 这个感觉就像大厨遇到百年难见的好材料,不炒个菜憋的慌, 机缘巧合周一周二两个晚上做了一个简单app,先看下效果: ios ...

  3. Entity Framework7 入门之全功能.NET(Console, WinForms, WPF等)使用EF7

    昨天,我们介绍了EF的新特性和开发计划,如果你还不了解,请移步 Entity Framework7 有哪些不同?现在开发到什么程度了? .今天,我们开学习全功能.NET(Full .NET)下使用EF ...

  4. Framework7 - 入门教程(安装、配置、创建一个H5应用)

    1,Framework7介绍 (1)Framework7 是一个开源免费的框架.可以用来开发混合移动应用(原生和 HTML 混合)或者开发 iOS & Android 风格的 WEB APP. ...

  5. framework7 入门(数据绑定)

    数据绑定是用template7,官网,framework7内置template7,不用单独下载,下面介绍一些简单的绑定 当你的数据是个数组 return{ data:function(){ let i ...

  6. framework7 入门(基础布局)

    个人认为framework7是个很好的移动端框架,自带路由.下拉刷新.无限加载.时间线.各种dialog.环形图等,基本能满足大部分app的需求,可以和vue,webpack 等各种搭配. 这里讲一下 ...

  7. dubbox ExceptionMapper Filter request response 数据获取 数据传递

    dubbx虽然是基于jboss的resteasy实现restfull,但是对resteasy原生的配置却不支持(可能是考虑到dubbo本事的设计模式及实现难度,但是和大部分framework的设计风格 ...

  8. 前端移动框架Framework7入门

    正版官网:https://framework7.io/  (英文) 对应国内:http://www.framework7.cn/ (中文) 本地构建步骤(Demo级别) 1.HTML结构 2.引入Fr ...

  9. Ember.js入门教程、博文汇总

    第一章 对象模型 Ember.js 入门指南——类的定义.初始化.继承 Ember.js 入门指南——类的扩展(reopen) Ember.js 入门指南——计算属性(compute properti ...

随机推荐

  1. Abd学习笔记

    Abd学习笔记 V快捷键:转正坐标 Tab快捷键:切换xyz或是长度角度 空格键快捷键:切换长度或弧度 Enter快捷键:确定方向x或y O快捷键:做辅助线 E:切换平面,分别有t,f,s Ra:创建 ...

  2. MinGW GCC 8.3.1 2019年2月23日 出炉啦

    GNU 2019-02-22 发布了 GCC 8.3 https://gcc.gnu.org/onlinedocs/8.3.0/ 有详细的说明 MinGW 上可用的 GCC 8.3.1 版本下载地址 ...

  3. cURL error 60: SSL certificate problem: unable to get local issuer

    github 问题连接 https://github.com/yabacon/paystack-php/wiki/cURL-error-60:-SSL-certificate-problem:-una ...

  4. iView -- TimePicker 自定义修改时间选择器选择时间面板样式

    iView官方组件展示效果: 期望的最终效果: 为什么要修改期望效果? 项目需要只选择小时,分钟跟秒的不需要,而官方并没有直接相关的小时组件或者是设置显示成小时或分钟或秒的时间选择器,因为自己直接修改 ...

  5. 初识C语言(三)

    C语言中的运算符 C语言中的运算就是对数据进行操作.处理的过程.运算符就是指定该运算的处理方式. C语言中的运算符: 算术运算符 赋值运算符 关系运算符 逻辑运算符 三目运算符 算数运算符 C语言中的 ...

  6. matlab读取图片的异常表现

    在对人脸图片进行对齐时,发现有两张人脸图片一直检测不到人脸,但这两张图片中的人脸明明很好检测(证件照),经过 排查,最终发现问题所在:图片的格式不对. img = imread("**.jp ...

  7. Typescript04---模块、命名空间

    在Typescript1.5 中,内部模块称作命名空间,外部模块成为模块 一.什么是模块? 模块就是一个或一组功能模块. 模块在其自身的作用域里执行,而不是在全局作用域里.意味着,模块中的变量.函数. ...

  8. word2vec并行实现小记

    word2vec能将文本中出现的词向量化,其原理建立在Mikolov的博士论文成果及其在谷歌的研究经验的基础上.与潜在语义分析(Latent Semantic Index, LSI).潜在狄立克雷分配 ...

  9. [原创]免固件开发USB2.0 FPGA方案 速度40Mbyte/s+

    USB 2.0接口,实测速度40Mbyte/s: 一个接口实现两种功能(USB2.0+FPGA配置): 免固件开发: 完整的FPGA代码,即拿即用: FPGA逻辑工程师开发USB接口福音: 平台可移植 ...

  10. MySQL 常用命令(Linux)

    一.查看MySQL服务 MySQL服务应该随开机自动启动的.正常情况下,查看开机自动启动的服务使用chkconfig命令,如下: chkconfig --list 实际mysql是否真正启动,是否真正 ...