首先说一下 ionic 是单页面应用,也就是说整个项目就有一个index.html, 那么问题就就来了, 如果我们不同的页面要分享给大家的是不同的链接和图片,应该怎么去做呢? 这就是我们今天要总结的东西. 今天这个问题真是闹得我心烦,有必要总结下来了.

学习重点:

  1. 微信分享方法巧妙封装
  2. 监听路由事件$rootScope.$on
  3. 举一反三

微信分享

关于微信分享,大家都是在熟悉不过了,无非就是调用微信的SDK,授权,给他分享索要的东西的ok。所以对于微信分享似乎没有什么好说的,但是细心的伙伴有木有发现,微信的分享并不是每次分享都去调用分享的方法,数据存进去每次分享都是拿上次的数据。

就因为这个我们在ionic单页面应用中倘若要实现每个页面都分享不同的信息,岂不是每个controller里面都要调用一次分享了,不然分享的信息都不会是你想要的,因为在Angular中controller不会重新加载一遍的哦!所以即便我们写了动态的数据,微信也压根不会理你的。你抱怨也没用,照我们老大的话就是:“你爱用不用喽”屌的很嘞!

Ionic中微信分享

言归正传,说我们今天的重点,就是怎么在ionic中实现不同页面分享不用的信息。

1、首先我创建一个名叫叫 share.js 的文件(PS:我们的需求就是聊天页面分享的是用户的头像和下载页,其他的都是公众号本身)

//这里的a为了区分是不是聊天页面,和分享不同很信息。很巧妙的一个用法
var setShareData = function(a){
//这里我们给一个默认值
var linkUrl = 'http://www.qinqimaifang.cn/qmspa/index.html';
var imgUrl = 'http://www.qinqimaifang.cn/qmspa/img/logo.png';
if(a>0){
linkUrl = sessionStorage.getItem('linkUrl');
imgUrl = sessionStorage.getItem('imgUrl');
};
wx.onMenuShareTimeline({
title: '如果买房时有困惑,来“亲戚买房”找他',
link: linkUrl,
imgUrl: imgUrl,
success: function (res) {
// 用户确认分享后执行的回调函数 },
cancel: function (res) { }
});
// 分享给朋友
wx.onMenuShareAppMessage({
title: '如果买房时有困惑,来“亲戚买房”找他',
desc: '地产老总一对一解答买房疑惑',
link: linkUrl,
imgUrl: imgUrl,
success: function () { },
cancel: function () { }
});
};

2, 监听路由事件$rootScope.$on

这里也是我们今天解决问题的重点所在,因为我们用的是ui-rooter,所以我们要想知道用户是不是在当前聊天页面。

$rootScope.$on('$stateChangeStart',function(event, toState, toParams, fromState, fromParams){
console.log(toState.name);
//这里判断当前的是不是聊天页面
if( 'tab.consultant_QA'.indexOf( toState.name)>=0 ){
// event.preventDefault();
//如果是就就传递参数1
setShareData(1);
}else{
//反之就是其他信息了
setShareData(0);
}
});

3. 调用

最后一步就是调用了,我们只需要在聊天的页面调用我们在share.js中定义的方法

//聊天页面controller
setShareData(1); //这里的传值很重要,因为是要判断你分享的是什么哦 //初始化页面的controller
setShareData(1);

举一反三

什么是举一反三,聪明的小伙伴都知道,就是在这个问题上我们就可以学习到怎么监听路由事件,之前我们知道angular加载一遍之后就不会重新的加载了,那时候第一想到的就是广播事件,现在我们是不是可以利用监听路由来巧妙的解决了呢?当然更多的问题都可以使用的。不仅仅限制微信分享的。今天分享就到这里了。祝大家学习愉快。

PS:代码优化可能不好,也许有更好的方法,欢迎大家一起来讨论哦!

ionic单页面应用中微信分享的问题总结的更多相关文章

  1. vue 单页应用中微信支付的坑

    vue 单页应用中微信支付的坑 标签(空格分隔): 微信 支付 坑 vue 场景 在微信H5页面(使用 vue-router2 控制路由的 vue2 单页应用项目)中使用微信 jssdk 进行微信支付 ...

  2. vue单页面应用中动态修改title

    https://www.jianshu.com/p/b980725b62e8 https://www.npmjs.com/package/vue-wechat-title 详细信息查看:vue-wea ...

  3. 解决vue单页面应用做微信JSSDK注入权限时出现“invalid signature”(ios端)

    --都说微信开发多坑,没想到遇到一个天坑. 在做一个vue项目时,要用到微信JS-SDK,官方文档详见:https://developers.weixin.qq.com/doc/offiaccount ...

  4. android APP 中微信分享功能实现 的总结

    //花了很长时间最终完成了微信分享功能,中间走了很多弯路,在此做一下小结,希望对在应用中使用到微信分享的朋友有所帮助. 主要问题就是下面两个: 1.为什么运行了项目之后,微信分享只是闪了一下就没有了? ...

  5. 【重点突破】—— 百度地图在React单页面应用中的使用

    前言:百度地图是网页中使用地图的常用第三方工具,这里结合React项目中学到的应用场景总结一些使用要点. 一.在网页中嵌入百度地图 搜百度地图开放平台,注册百度开发者账号 控制台:查看应用.创建应用( ...

  6. ShareSDK中微信分享错误总结

    项目中用到微信分享,可向好友或朋友圈分享链接时,分享人可以打开网站,查看消息者却始终不能打开网站.试了N种方法,重写了N次分享模块,均没办法解决. 在无意中查看分享链接时发现,朋友圈里分享后,原始链接 ...

  7. 纯JS单页面赛车游戏代码分享

    分享一个以前写的小游戏,纯js游戏,代码很简单.欢迎大家来喷呦! 效果图: 代码展示://直接复制到html文件即可 支持IE9+版本 <!DOCTYPE html> <html&g ...

  8. 在Vue单页面应用中使用Promise链式调用

    eg: this.commonLoginFun().then((res) => { if (res.errNo === 0) { const { isLogin } = res.data; if ...

  9. vue单页面项目中解决安卓4.4版本不兼容的问题

    1.cnpm安装 cnpm i babel-polyfill --save cnpm i es6-promise --save 2.main.js引入 import ‘babel-polyfill‘ ...

随机推荐

  1. Android 网络开发之WIFI

    WIFI就是一种无线联网技术,常见的是使用无线路由器.那么在这个无线路由器的信号覆盖的范围内都可以采用WIFI连接的方式进行联网.如果无线路由器连接了一个ADSL线路或其他的联网线路,则又被称为&qu ...

  2. linux下用用iptables做端口映射的shell

    情形一:跨网络.跨主机的映射Full-Nat 我们想到达主机B的80端口,但是由于网络限制可能无法直接完成.但是我们可以到达主机A的8080端口,而主机A可以直接到达B的80端口.这时候可以使用ipt ...

  3. 【转】如何查看当前Open的Cursor

    遇到错误:A cursor with thename ' ' already exists,想要看是什么代码导致的.找到下面几种方法. --测试声明Cursor并且打开 DECLARE vend_cu ...

  4. 05 技术内幕 T-SQL 查询读书笔记(第四章)

    第四章 子查询:在外部查询内嵌套的内部查询(按照期望值的数量分为,标量子查询 scalar subqueries,多值子查询multivalued subqueries)(按照子查询对外部查询的依赖性 ...

  5. 通知Notification

    步骤: 1.调用getSystemService()获取NotificationManager:NotificationManager manager = (NotificationManager)g ...

  6. Angular Mobile UI API文档

    这个是angular-mobile-ui的主要模块 应用这个模块你也将同时获取到mobile-angular-ui.core和mobile-angular-ui.components的特性 他不在需要 ...

  7. SLAM初探-SLAM for Dummies

    SLAM综述性特别是原理讲述比较浅显易懂的的资料比较少,相对比较知名的是<SLAM for Dummies>,但中文资料相对较少,这里就简单概述一下<SLAM for Dummies ...

  8. React 快速入门小记

    大约半个月前,我一直在思考一个问题,Angular.React 和 Vue,究竟该学什么? 听取了几位前辈的意见,也综合考虑了各方面的原因,最终选择了 React,希望我"没有选错" ...

  9. 关于json-p

    关于json-p 目录 关于json-p json-p是什么 json-p原理分析 json-p的缺点 json-p是什么 json-p实际上是一种跨域ajax发送http请求的方法,它不是什么全新的 ...

  10. linux应用程序开发-进程通信(IPC)

    IPC why: 1.数据传输 2.资源共享 目的: 3.通知事件 4.进程控制 发展: 1.UNIX进程间通信 2.基于SYStem V 3.POSIX 方式分类: 1.pipe(管道) FIFO( ...