首页 > web前端 > js教程 > 正文

AngularJS通过路由模块ui-sref指令跳转页面传参方法

一个新手
发布: 2017-09-23 09:35:51
原创
3732人浏览过

路由router.js

'use strict';

angular.module('app').config(['$stateProvider', '$urlRouterProvider', function($stateProvider, $urlRouterProvider) {
  $stateProvider.state('main', {
    url: '/main',
    templateUrl: 'view/main.html',
    controller: 'mainCtrl'
  }).state('position', {
    url: '/position/:id',                  //这里需要传入一个id的参数放在url后面传递过去
    templateUrl: 'view/position.html',
    controller: 'positionCtrl'
  });
  $urlRouterProvider.otherwise('main');
}])
登录后复制

控制器controller

<p style="margin-bottom: 7px;">'use strict'angular.module('app').controller('mainCtrl',['$scope',function($scope){<br/>    $scope.list = [{<br/>        id:'1',                             //将这个id写到页面上<br/>        name:'销售',<br/>        imgSrc:'image/company-3.png',<br/>        companyName: '千度',<br/>        city: '上海',<br/>        industry: '互联网',<br/>        time: '2016-06-01 11:05'<br/>    },{<br/>        id:'2',<br/>        name:'WEB前端',<br/>        imgSrc:'image/company-1.png',<br/>        companyName: '慕课网',<br/>        city: '北京',<br/>        industry: '互联网',<br/>        time: '2016-06-01 01:05'<br/>    }];<br/>}]);<br/></p>
登录后复制

html模板

<ul class="bg-w position-list">//通过ui-sref="position({id:item.id})"的方式将参数传递过去    
            <li ui-sref="position({id:item.id})" class="item" ng-repeat="item in data">
        <img class="f-l logo" ng-src="{{item.imgSrc}}" alt="">
        <h3 class="title" ng-bind="item.name"></h3>
        <p class="text" ng-bind="item.companyName+'
                ['+item.city+']'+' '+item.industry"></p>
        <p class="text" ng-bind="item.time"></p>
    </li></ul>
登录后复制

获取路由上参数:
注入$state服务,$state服务下有个$state.params属性,这个$state.params属性是个json对象,这个json对象所包含的数据就是我们前面传入的参数。

云雀语言模型
云雀语言模型

云雀是一款由字节跳动研发的语言模型,通过便捷的自然语言交互,能够高效的完成互动对话

云雀语言模型 54
查看详情 云雀语言模型
'use strict';
angular.module('app').controller('positionCtrl',['$q','$http','$state','$scope',function ($q,$http,$state,$scope) {

              //获取id的参数,并用$http请求对应的数据
              $http.get('/data/position?id='+$state.params.id).success(fn1).error(fn2);

}]);
登录后复制

AngularJS跨页面传参方式小结:
①在路由中声明url: ‘/url/:参数’;
②获取数据通过ui-sref=”url({id:item.id})”的方式将参数挂载到url后面;
③在控制器中注入$state服务,利用\$state.params属性获取传过来的参数。

AngularJS传参

以上就是AngularJS通过路由模块ui-sref指令跳转页面传参方法 的详细内容,更多请关注php中文网其它相关文章!

相关标签:
路由优化大师
路由优化大师

路由优化大师是一款及简单的路由器设置管理软件,其主要功能是一键设置优化路由、屏广告、防蹭网、路由器全面检测及高级设置等,有需要的小伙伴快来保存下载体验吧!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号