ionic 跨页面传值的几种方法
Posted 菜鸟丫丫
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ionic 跨页面传值的几种方法相关的知识,希望对你有一定的参考价值。
1、使用AngularJS自带的$cacheFactory服务
$cacheFactory 从字面直译即为缓存工厂,可以用它来生成缓存对象,缓存对象以key-value的方式进行数据的存储,在整个应用内是单例的,可以在service或者controller中注入这个服务,然后就可以用它来自由的存取对象以及各种变量,下面是一个简单例子
- .controller(‘AppCtrl‘, function ($scope, $ionicModal, $timeout, $cacheFactory) {
-
- var user = {name: ‘jax‘, age: 18, sex: ‘男‘};
- var user_cache = $cacheFactory("user_cache");
- user_cache.put("lol",user);
- .controller(‘PlaylistCtrl‘, function ($scope, $stateParams, $cacheFactory) {
- var user_cache = $cacheFactory.get("user_cache");
- var user = user_cache.get("lol");
-
-
-
- console.log(user);
- });
当从AppCtrl对应页面切换到PlaylistCtrl对应的页面时,浏览器控制台打印结果:
$cacheFactory常用的几个方位api如下:
- {{*}}
get({string} key)
— 返回与key
对应的value
值,如果未命中则返回undefined
。
- {void}
remove({string} key)
— 从缓存中删除一个键值对
- {void}
removeAll()
— 删除所有缓存中的数据
- {void}
destroy()
— 删除从$cacheFactory
引用的这个缓存.
2、使用url传参
例:playlists.htm页面将 playlist.id 传递到 playlist页面
- <ion-item href="#/app/playlists/{{playlist.id}}">
- .controller(‘PlaylistCtrl‘, function ($scope, $stateParams, $cacheFactory) {
- var user_cache = $cacheFactory.get("user_cache");
- var user = user_cache.get("lol");
-
-
-
- console.log(user);
-
- var playlistId=$stateParams.playlistId;
- console.log("playlistId:"+playlistId);
- });
需要注意的是必须在app.js路由中配置接受这个参数
- .state(‘app.single‘, {
- url: ‘/playlists/:playlistId‘, //配置多个参数用:a/:b/:c
- views: {
- ‘menuContent‘: {
- templateUrl: ‘templates/playlist.html‘,
- controller: ‘PlaylistCtrl‘
- }
- }
3、service或者factory传值(service跟factory中都是单例模式,定义的变量在整个应用内唯一)
定义变量data
- angular.module(‘starter.controllers‘, [])
- .service(‘dataService‘,function () {
- var data="I come from service";
- return{
- getData:function () {
- return data;
- }
- }
- })
在controller中取出变量
- .controller(‘PlaylistCtrl‘, function ($scope, $stateParams, $cacheFactory,dataService) {
- console.log("sercice data:"+dataService.getData());
- });
4、使用H5本地存储localStorage或者sessionStorage(还有indexDB,websql在数据量较大情况下使用)
getItem //取记录
setItem//设置记录
removeItem//移除记录
key//取key所对应的值
clear//清除记录
键值对存储,用法也是非常简单,上面给出了常用的api,
1、使用AngularJS自带的$cacheFactory服务
$cacheFactory 从字面直译即为缓存工厂,可以用它来生成缓存对象,缓存对象以key-value的方式进行数据的存储,在整个应用内是单例的,可以在service或者controller中注入这个服务,然后就可以用它来自由的存取对象以及各种变量,下面是一个简单例子
- .controller(‘AppCtrl‘, function ($scope, $ionicModal, $timeout, $cacheFactory) {
-
- var user = {name: ‘jax‘, age: 18, sex: ‘男‘};
- var user_cache = $cacheFactory("user_cache");
- user_cache.put("lol",user);
- .controller(‘PlaylistCtrl‘, function ($scope, $stateParams, $cacheFactory) {
- var user_cache = $cacheFactory.get("user_cache");
- var user = user_cache.get("lol");
-
-
-
- console.log(user);
- });
当从AppCtrl对应页面切换到PlaylistCtrl对应的页面时,浏览器控制台打印结果:
$cacheFactory常用的几个方位api如下:
- {{*}}
get({string} key)
— 返回与key
对应的value
值,如果未命中则返回undefined
。
- {void}
remove({string} key)
— 从缓存中删除一个键值对
- {void}
removeAll()
— 删除所有缓存中的数据
- {void}
destroy()
— 删除从$cacheFactory
引用的这个缓存.
2、使用url传参
例:playlists.htm页面将 playlist.id 传递到 playlist页面
- <ion-item href="#/app/playlists/{{playlist.id}}">
- .controller(‘PlaylistCtrl‘, function ($scope, $stateParams, $cacheFactory) {
- var user_cache = $cacheFactory.get("user_cache");
- var user = user_cache.get("lol");
-
-
-
- console.log(user);
-
- var playlistId=$stateParams.playlistId;
- console.log("playlistId:"+playlistId);
- });
需要注意的是必须在app.js路由中配置接受这个参数
- .state(‘app.single‘, {
- url: ‘/playlists/:playlistId‘, //配置多个参数用:a/:b/:c
- views: {
- ‘menuContent‘: {
- templateUrl: ‘templates/playlist.html‘,
- controller: ‘PlaylistCtrl‘
- }
- }
3、service或者factory传值(service跟factory中都是单例模式,定义的变量在整个应用内唯一)
定义变量data
- angular.module(‘starter.controllers‘, [])
- .service(‘dataService‘,function () {
- var data="I come from service";
- return{
- getData:function () {
- return data;
- }
- }
- })
在controller中取出变量
- .controller(‘PlaylistCtrl‘, function ($scope, $stateParams, $cacheFactory,dataService) {
- console.log("sercice data:"+dataService.getData());
- });
4、使用H5本地存储localStorage或者sessionStorage(还有indexDB,websql在数据量较大情况下使用)
getItem //取记录
setItem//设置记录
removeItem//移除记录
key//取key所对应的值
clear//清除记录
键值对存储,用法也是非常简单,上面给出了常用的api, 以上是关于ionic 跨页面传值的几种方法的主要内容,如果未能解决你的问题,请参考以下文章
js实现页面与页面之间传值的几种方法优劣
ASP.NET 页面之间传值的几种方式
小程序页面传值的几种方式
ionic项目中跨页面传递参数的几种方式
求助。asp.net 比较GET和POST传值方法
vue中请求的几种方式