详解AngularJS跨页面传值ui-router

博主用的ionic 这里使用ui-router传值,用来在跳转页面的同时带着你想带走的东西一起跳走

(PS:博主半路出家,尚是菜鸟,写的东西自己跑起来并没有什么问题但不敢保证写的一定对,语言也很随意,仅供参考。另,期待各位前辈的指教)

博主用的ionic

这里使用ui-router传值,用来在跳转页面的同时带着你想带走的东西一起跳走

需求是这样的,我有一个商品单子(概览页),点一个商品就可以去看它的详情(详情页) 要解决的问题就是把概览页被点击的商品的id传给详情页,详情页拿着这个id给后台后台返回对应的需要的json

下面开始实现

rush:js;"> .controller('CafeCtrl',function($scope,cafeData,$state) { //往外传值的controller里加一个$state $scope.cafeList = cafeData.All(); $scope.goDetail = function(id) { $state.go('itemDetail',{sort : "cafe",id : id}); //就拿它传 }; })

在传值的一行:

rush:js;"> $state.go('itemDetail',id : id}); //前面的是变量名,后边的是值

我的理解是:塞了两个变量到一个中转的名叫$stateParams的什么东西里面,controller里面写法就是这样子的,页面上ng-click="goDetail(item.id)"调用它就可以了

app.js里,接收值的页面(详情页).state这么写,留两个位置给刚才传出来的东西

rush:js;"> .state('itemDetail',{ url: '/itemDetail/:sort/:id/',//这里就是那两个要传的东西,名字要对应相同 templateUrl: 'templates/itemDetail.html',controller: 'ItemDetailCtrl' })

然后再去接收值的页面(详情页)接收这俩值存俩对象里面(接受并存下了传来的两个值)

rush:js;"> .controller('ItemDetailCtrl',$stateParams,$state) { //加个$stateParams $scope.sort = $stateParams.sort; $scope.itemId = $stateParams.id; })

在上面加个$stateParams,然后下面scope一个对象,把你要的值从$stateParams里面拿点儿出来赋值给它就ok了

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...