angularjs实现页面跳转并进行参数传递

Angular页面传参有多种办法,我在此列举4种最常见的:

1. 基于ui-router的页面跳转传参

(1) 在AngularJS的app.js中用ui-router定义路由,比如现在有两个页面,一个页面(producers.html)放置了多个producers,点击其中一个目标,页面跳转到对应的producer页,同时将producerId这个参数传过去。

.state('producers', {

url: '/producers',

templateUrl: 'views/producers.html',

controller: 'ProducersCtrl'

})

.state('producer', {

url: '/producer/:producerId',

templateUrl: 'views/producer.html',

controller: 'ProducerCtrl'

})

(2) 在producers.html中,定义点击事件,比如ng-click="toProducer(producerId)",在ProducersCtrl中,定义页面跳转函数 (使用ui-router的$state.go接口):

.controller('ProducersCtrl', function ($scope, $state) {

$scope.toProducer = function (producerId) {

$state.go('producer', {producerId: producerId});

};

});

(3) 在ProducerCtrl中,通过ui-router的$stateParams获取参数producerId,譬如:

.controller('ProducerCtrl', function ($scope, $state, $stateParams) {

var producerId = $stateParams.producerId;

});

2. 基于factory的页面跳转传参

举例:你有N个页面,每个页面都需要用户填选信息,最终引导用户至尾页提交,同时后一个页面要显示前面所有页面填写的信息。这个时候用factory传参是比较合理的选择(下面的代码是一个简化版,根据需求可以不同定制):

.factory('myFactory', function () {

//定义factory返回对象

var myServices = {};

//定义参数对象

var myObject = {};

/**

* 定义传递数据的set函数

* @param {type} xxx

* @returns {*}

* @private

*/

var _set = function (data) {

myObject = data;

};

/**

* 定义获取数据的get函数

* @param {type} xxx

* @returns {*}

* @private

*/

var _get = function () {

return myObject;

};

// Public APIs

myServices.set = _set;

myServices.get = _get;

// 在controller中通过调set()和get()方法可实现提交或获取参数的功能

return myServices;

});

3. 基于factory和$rootScope.$broadcast()的传参

(1) 举例:在一个单页中定义了nested views,你希望让所有子作用域都监听到某个参数的变化,并且作出相应动作。比如一个地图应用,某个$state中定义元素input,输入地址后,地图要定位,同时另一个状态下的列表要显示出该位置周边商铺的信息,此时多个$scope都在监听地址变化。PS: $rootScope.$broadcast()可以非常方便的设置全局事件,并让所有子作用域都监听到。

.factory('addressFactory', ['$rootScope', function ($rootScope) {

// 定义所要返回的地址对象

var address = {};

// 定义components数组,数组包括街道,城市,国家等

address.components = [];

// 定义更新地址函数,通过$rootScope.$broadcast()设置全局事件'AddressUpdated'

// 所有子作用域都能监听到该事件

address.updateAddress = function (value) {

this.components = value.slice();

$rootScope.$broadcast('AddressUpdated');

};

// 返回地址对象

return address;

}]);

(2) 在获取地址的controller中:// 动态获取地址,接口方法省略

var component = {

addressLongName: xxxx,

addressShortName: xxxx,

cityLongName: xxxx,

cityShortName: xxxx

};

// 定义地址数组

$scope.components = [];

$scope.$watch('components', function () {

// 将component对象推入$scope.components数组

components.push(component);

// 更新addressFactory中的components

addressFactory.updateAddress(components);

});

(3) 在监听地址变化的controller中:// 通过addressFactory中定义的全局事件'AddressUpdated'监听地址变化

$scope.$on('AddressUpdated', function () {

// 监听地址变化并获取相应数据

var street = address.components[0].addressLongName;

var city = address.components[0].cityLongName;

// 通过获取的地址数据可以做相关操作,譬如获取该地址周边的商铺,下面代码为本人虚构

shopFactory.getShops(street, city).then(function (data) {

if(data.status === 200){

$scope.shops = data.shops;

}else{

$log.error('对不起,获取该位置周边商铺数据出错: ', data);

}

});

});

4. 基于localStorage或sessionStorage的页面跳转传参

注意事项:通过LS或SS传参,一定要监听变量,否则参数改变时,获取变量的一端不会更新。AngularJS有一些现成的WebStorage dependency可以使用,譬如gsklee/ngStorage · GitHub,grevory/angular-local-storage · GitHub。下面使用ngStorage来简述传参过程:

(1) 上传参数到localStorage - Controller A

// 定义并初始化localStorage中的counter属性

$scope.$storage = $localStorage.$default({

counter: 0

});

// 假设某个factory(此例暂且命名为counterFactory)中的updateCounter()方法

// 可以用于更新参数counter

counterFactory.updateCounter().then(function (data) {

// 将新的counter值上传到localStorage中

$scope.$storage.counter = data.counter;

});

(2) 监听localStorage中的参数变化 - Controller B

$scope.counter = $localStorage.counter;

$scope.$watch('counter', function(newVal, oldVal) {

// 监听变化,并获取参数的最新值

$log.log('newVal: ', newVal);

});

AngularJS进阶(八)实现页面跳转并进行参数传递的更多相关文章

  1. JSP 页面跳转中的参数传递

    1. 从一个 JSP 页面跳转到另一个 JSP 页面时的参数传递 1)使用 request 内置对象获取客户端提交的信息 2)使用 session 对象获取客户端提交的信息 3)利用隐藏域传递数据 4 ...

  2. flask学习(八):页面跳转和重定向

    1. 用处:在用户访问一些需要登录的页面的时候,如果用户没有登录,那么让页面重定向到登录页面 2. 实例 运行效果: 用户已登录,进入发布问答页面 用户未登录,跳转到登录页面

  3. 关于js单页面实现跳转原理以及利用angularjs框架路由实现单页面跳转

    还记得我们刚开始学习html时使用的锚节点实现跳转吗? <a href="#target">我想跳转至目标位置</a> <p>第一条</p ...

  4. IE下angularJS页面跳转的bug

    用Angularjs做项目的过程中遇到一种情况:就是在IE浏览器下,当访问网站页面后,点击浏览器中的向左和向右(返回和前进)按钮时,需要点击两次才能正确跳转,但是在chrome及其他浏览器下该bug没 ...

  5. ThinkPHP页面跳转、Ajax技巧详细介绍(十八)

    原文:ThinkPHP页面跳转.Ajax技巧详细介绍(十八) ThinkPHP页面跳转.Ajax技巧详细介绍 一.页面跳转 $this->success('查询成功',U('User/test' ...

  6. angularjs项目的页面跳转如何实现

    链接:https://www.zhihu.com/question/33565135/answer/696515Angular页面传参有多种办法,根据不同用例,我举5种最常见的:PS: 在实际项目中, ...

  7. [Xcode 实际操作]九、实用进阶-(24)使用Segue(页面的跳转连接)进行页面跳转并传递参数

    目录:[Swift]Xcode实际操作 本文将演示使用Segue(页面的跳转连接)进行页面跳转并传递参数. 参照结合:[Xcode10 实际操作]九.实用进阶-(23)多个Storyboard故事板中 ...

  8. 网站开发进阶(三十七)JSP页面跳转问题解决

    JSP页面跳转问题解决 PS:本篇博文质量欠佳,仅供个人学习之用. 前言 在做Web开发时,对别人的应用(jsp+servlet)进行服务器部署时出现了页面跳转无效的情况.但是项目在本地未出现此状况. ...

  9. [Xcode 实际操作]九、实用进阶-(23)多个Storyboard故事板中的页面跳转

    目录:[Swift]Xcode实际操作 本文将演示多个Storyboard故事板中的页面跳转. 使用快捷键[Command]+[N]创建一个新的故事板文件. (在项目文件夹[DemoApp]上点击鼠标 ...

随机推荐

  1. 剑指offer面试题6 重建二叉树(java)

    注:(1)java中树的构建 (2)构建子树时可以直接利用Arrays.copyOfRange(preorder, from, to),这个方法是左开右闭的 package com.xsf.SordF ...

  2. 1.关于QT中的Graphics绘图,定时器,动画,将窗口中的内容打印到图片上,打印机,打印预览

     1 新建项目 A  修改pro中的内容如下: HEADERS += \ MyWidget.h SOURCES += \ MyWidget.cpp QT += gui widgets prints ...

  3. Java Socket输入流如何检测到EOF

    对于InputStream的 read(b, off, len) 方法 public int read(byte[] b, int off, int len) throws IOException,J ...

  4. Android的ToggleButton和Switch以及AnalogColok和DigitalColok的用法-android学习之旅(二十)

    ToggleButton 和Switch简介 ToggleButton 和Switch都是继承了Button,所以他们的属性设置和Button差不多. 分别支持的属性 ToggleButton 的属性 ...

  5. 剑指Offer——二叉树

    剑指Offer--二叉树 前言 数据结构通常是编程面试中考察的重点.在参加面试之前,应聘者需要熟练掌握链表.树.栈.队列和哈希表等数据结构,以及它们的操作.本片博文主要讲解二叉树操作的相关知识,主要包 ...

  6. Android开发工具下载地址

    Android Studio: http://zdz.la/iq4zSa

  7. ECMAScript 6之Set和Map数据结构

    Set 基本用法 ES6提供了新的数据结构Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set本身是一个构造函数,用来生成Set数据结构. var s = new Set(); [2, ...

  8. Mybatis简单入门

    MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的XML或注解用 ...

  9. SQLServer导出数据到MySQL

    1从SQLServer导出数据 执行BCP: bcp "..." queryout "F:\test.txt" -c –S1.2.3.4 -Usa -P1111 ...

  10. 【一天一道LeetCode】#115. Distinct Subsequences

    一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given a ...