数据获取

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. 【原创】用python连接thrift Server 去执行sql的问题总汇

    场景:python和现有产品的结合和应用——python的前瞻性调研 环境:centos7 0.首先确保安装了python和pyhive,下面是连接代码: #!/usr/bin/env python ...

  2. filp_open/filp_close/vfs_read/vfs_write

    Linux系统成功的关键因素之一就是具有与其他操作系统和谐共存的能力.Linux系统的文件系统由两层结构构建:第一层是虚拟文件系统(VFS),第二层是各种不同的具体的文件系统. VFS就是把各种具体的 ...

  3. 【玩转开源】基于Docker搭建Bug管理系统 MantisBT

    环境Ubuntu18.04 + Docker 1. Docker Hub 链接:https://hub.docker.com/r/vimagick/mantisbt 这里直接使用docker命令的方式 ...

  4. python3下的twistedPOST请求网页

    在python2中我们使用twisted比较方便,网上资料也比较多,但是通常在python3中使用的时候,并不能成功.我也是找了好多资料没有成功之后,自己去尝试做小白鼠,测试了很久之后,发现传递给tw ...

  5. Echarts折线图案例

    公司要求做个累计收益图,没用过Echarts,再这里记录一下 html页面 <!DOCTYPE html> <html> <head> <meta chars ...

  6. docker 安装kafka

    1.下载镜像这里使用了wurstmeister/kafka和wurstmeister/zookeeper这两个版本的镜像 docker pull wurstmeister/zookeeperdocke ...

  7. C++构造函数和析构函数的调用顺序

    1.构造函数的调用顺序 基类构造函数.对象成员构造函数.派生类本身的构造函数 2.析构函数的调用顺序 派生类本身的析构函数.对象成员析构函数.基类析构函数(与构造顺序正好相反) 3.特例 局部对象,在 ...

  8. 部分手机浏览器存在将ajax请求当成广告过滤的情况,及解决方案

    我们发现h5页面在某些浏览器请求不到数据,经过排查,是浏览器的广告拦截模块搞的鬼. 通过删减参数,发现adtype和adnum参数去掉后,接口可以正常请求,开始以为是官方拦截关键词带有ad的参数,后来 ...

  9. Pytoch机器学习乱玩(一):数学建模作业,体重与心率

    动物心率与体重的模型 动物消耗的能量p主要用于维持体温,而体内热量通过其表面积S散失,记动物体重为w,则\(P \propto S \propto w^{\alpha}\).又\(P\)正比于血流量\ ...

  10. easynetq发布订阅demo实现注意事项

    最近开始在项目中使用easynetq,大概了解了下api,在网上看了下示例,结果没有一个运行成功的,一个最简单的发布订阅都没有成功.我是直接运行起来别人的示例,不应该啊,后来一直分析一直分析,最后发现 ...