ui-router是怎样传参的

今天碰到一个需求,同事开发的业务中需要跳到我的业务中,并传递参数过来,这就需要将参数通过url路由传递过来。在angularjs中该怎样做呢?

我们知道通常路由控制都是通过引用ui-router库,调用$stateProvider和$urlRouterProvider服务来控制的,想要在路由中传递参数还是要找它们来解决。下面来分别说一下它们各自是怎么工作的。

$urlRouterProvider

$urlRouterProvider一般处理在状态配置中指定的url路由方式之外的 url 请求的路由方式。

$urlRouterProvider.otherwise('/index');

这个东西能不能在路由过程中传递参数还没有实践过,等研究清楚了再来细说。

$stateProvider

在$stateProvider中我们通常是这么设置的:

$stateProvider.state('search', {
    url: '/search',
    views: {
        'header': {
            templateUrl: "../common/header/head_nav.html",
            controller: 'headerCtrl'
        },
        'appState': {
            templateUrl: '../search/search.html',
            controller: "searchCtrl"
        }
    }
});

这里我们定义了一个路由search,里面包含了ui-view需要加载的视图和controller。现在我们给这个路由添加参数:

$stateProvider.state('search', {
    url: '/search/{id}',
    views: {
        'header': {
            templateUrl: "../common/header/head_nav.html",
            controller: 'headerCtrl'
        },
        'appState': {
            templateUrl: '../search/search.html',
            controller: "searchCtrl"
        }
    }
});

只需要花括号里面定义参数名就完成了,就是这么简单。而且不用花括号,使用冒号也是可以的:

$stateProvider.state('search', {
    url: '/search/:id',
    views: {
        'header': {
            templateUrl: "../common/header/head_nav.html",
            controller: 'headerCtrl'
        },
        'appState': {
            templateUrl: '../search/search.html',
            controller: "searchCtrl"
        }
    }
});

两种方式有什么区别呢?简单说就是花括号的形式功能更加强大,花括号里面是可以添加正则表达式的:

$stateProvider.state('search', {
    url: '/search/{id:[0-9]{1,8}}',
    views: {
        'header': {
            templateUrl: "../common/header/head_nav.html",
            controller: 'headerCtrl'
        },
        'appState': {
            templateUrl: '../search/search.html',
            controller: "searchCtrl"
        }
    }
});

甚至你还可以使用传统的http的get方式添加参数:

url: '/search?id&name'
//匹配 url: '/search?id=value1&name=value2'

很灵活很强大吧~接下来就是在到达页面获取到这些参数,这需要用到$stateParams服务。

controller: function($stateParams){
  $stateParams.id
  $stateParams.name
}

如果url中没有该参数,我们会得到undefined。

更详细的说明可以参考这里:https://github.com/angular-ui/ui-router/wiki/URL-Routing

时间: 2025-01-28 10:10:59

ui-router是怎样传参的的相关文章

springMVC3.0(文件上传,@RequestMapping加参数,@SessionAttributes,@ModelAttribute,转发,重定向,数值获取,传参,ajax,拦截器)

1.项目包结构如下: 2.       spring配置文件springMVC.xml修改如下: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  xml

aspx页面Url传参在火狐浏览器下Page_Load执行两次的Bug

问题描述 机器环境:Xpsp3+Vs2010+Firefox28.0问题描述:新建一个空的Website,加入一个a.aspx和b.aspxa.aspx页面代码<%@PageLanguage="C#"AutoEventWireup="true"CodeFile="a.aspx.cs"Inherits="a"%><!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transi

angular.js 路由及页面传参

页面传参数方法:1.$rootScope.2.(url)/user/:name/:age. 页面转换方法:1.href="#/".2.$state.go.3.$location.path.4.ui-sref (1)自带路由ngRoute <html> <head> <meta charset="utf-8"> <title>AngularJS 路由实例</title> </head> <b

Angularjs中UI Router全攻略_AngularJS

首先给大家介绍angular-ui-router的基本用法. 如何引用依赖angular-ui-router angular.module('app',["ui.router"]) .config(function($stateProvider){ $stateProvider.state(stateName, stateCofig); }) $stateProvider.state(stateName, stateConfig) stateName是string类型 stateCon

js中window.showModalDialog各浏览器居中和传参实例兼以及一些兼容性问题

  浏览器居中以及传参实例 window.showModelDialog可设置center参数为yes,保证其在子窗口在父窗口居中. 但是该参数只对IE浏览器有效,对火狐无效,只有通过计算模态窗口的居中位置.   解决办法 function openShowModalDialog(url,param,whparam,e){    // 传递至子窗口的参数  var paramObj = param || { };    // 模态窗口高度和宽度  var whparamObj = whparam

图片-jsp页面传参问题(参数长度太长)

问题描述 jsp页面传参问题(参数长度太长) < img src=""../admin/image-read.action?icode=${data.icode}""/> 其中icode是一个图片的二进制数据串,比较长,传不到后台.有什么其他方法? 解决方案 这个方式肯定不行啊,虽然没明白你是不是直接从前台获取一个本地图片然后在jsp中转成二进制的,但是这样肯定传不了的.可以使用ajax form提交提交后也不刷新当前页面. 解决方案二: jsp页面传到

Javascript实例教程:点击传参方法和鼠标事件方法

文章简介:从这张开始就和大家说一些实用的效果的写法.当然首当其冲的就是我们可爱的TAB选项卡,用JQ写选项卡当然是很方便的而且方法也很多.其实用原生的JS写选项卡方法也很多. 从这张开始就和大家说一些实用的效果的写法.当然首当其冲的就是我们可爱的TAB选项卡,用JQ写选项卡当然是很方便的而且方法也很多.其实用原生的JS写选项卡方法也很多.下面我就写几个给大家看看一,点击传参方法<script>function tab(dom){var list = document.getElementByI

jsp页面传参乱码的解决方法

 本篇文章主要是对jsp页面传参乱码的解决方法进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助 jsp页面传参乱码的解决方法   jsp页面js:   encodeURIComponent要使用两次 encodeURIComponent(encodeURIComponent(userAccount));   java: String  userAccount = java.net.URLDecoder.decode(userAccount,"UTF-8");/*需要处理异常*/

jsp中文页面乱码与传参乱码

  页面乱码 这种乱码的原因是应为没有在页面里指定使用的字符集编码,解决方法:只要在页面开始地方用下面代码指定字符集编码即可 代码如下   <%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="err.jsp" %> 数据库乱码 这种乱码会使你插入数据库的中文变成乱码,或者读出显

PHP传参之传值与传址的区别

  PHP传参之传值与传址的区别         这篇文章主要介绍了PHP传参之传值与传址的区别,十分的简单,大家通过实例简单对比下就明白了,有需要的小伙伴可以参考下. 废话不多说,先来看段代码 ? 1 2 3 function test(&val){ return $val; } 其中为什么用到&进行传参呢,有什么好处? 传址是允许在函数内部进行改变的意思,比如: ? 1 2 3 4 5 6 7 $test = "hello"; function myFun(&