搜索
首页web前端html教程ui-router的使用_html/css_WEB-ITnose

使用时需要ui中用ui-view指令指定 如:

<div ui-view></div>

首先配置注册 ui-route

var mainModule = angular.module('main', ['ui.router']);

由于run方法是在angular启动的时候就会执行的,可以将路由跳转控制放到run方法中,比如某种条件下禁止路由跳转 另外全局事件也可以放到run方法中

mainModule.run(function($rootScope,$state,$http,$stateParams){    //这里把$state和$stateParams这两个对象放到$rootScope上,方便其它地方引用和注入。    $rootScope.$state = $state;    $rootScope.$stateParams = $stateParams;    $rootScope.$on('$stateChangeStart', function(event, toState,                        toParams, fromState, fromParams) {                    if (toState.name === "yxlpm") {                        // 这里加入调出影响力排名页面是做出的判断                        //使用jquery不使用$http是应为$http的请求是不定时的,等请求完成页面已经完成了跳转,evet事件就无效                        // 如果好友公司数少于5个侧不显示页面,跳出提示                        $.ajax({                                    method : 'POST',                                    url : '../userInfo/influence',                                    async: false,                                    headers : {                                        'token' : $rootScope.token                                    }                                }).success(                                function(resp, status, headers, config) {                                    if (resp.code === 8037) {//                                        $state.go('wo');   路由跳转go方式                                        event.preventDefault();// 取消默认跳转行为                                        alert('您的影响力不足无法查看');                                    }                                });                    }                });})

基本路由配置

mainModule.config(function($stateProvider, $urlRouterProvider) {        // $urlRouterProvider.otherwise('../dongtai/smdt.html');        // //在配置(状态配置和when()方法)中没有找到url的任何匹配        $stateProvider.state('news', {                    url : '/news/:type', // 消息   type为参数类型  取参数可用$stateParams.type                    templateUrl : '../grsz/news.html'                }).state('sousuo.zrssjg', {                      url : '/zrssjg/:topic', // 找人结果                    templateUrl : '../sousuo/zrssjg.html'                }).state('zwxq', {                    //注意这边嵌套视图的写法                    url : '/zwxq/:id', // 职位详情                    views : {                        'view1' : {                            templateUrl : '../wo/zwxq.html'                        },                        ‘view2’:{                            templateUrl : '../wo/zlxq.html'                        }                    }                })    });    html:    //传参方式1、/news/1      反斜杆后面为参数    <a class="menu-item" href="#/news/1" hideblock>          消息    </a>    //传参方式2、topic为参数名    用.号来控制sousuo页面下的子页面    <a class="tag" ui-sref="sousuo.zrssjg({topic:ChildrenPosition.name})"</a>    //指定路由    <div ui-view="view1"></div>     <div ui-view="view2"></div>(7) 事件

state事件

    //状态改变之前触发    $rootScope.$on('$stateChangeStart', function(event, toState, toParams, fromState, fromParams){ ... })    $rootScope.$on('$stateNotFound', function(event, unfoundState, fromState, fromParams){ ... })    //example    // somewhere, assume lazy.state has not been defined$state.go("lazy.state", {a:1, b:2}, {inherit:false});// somewhere else$rootScope.$on('$stateNotFound', function(event, unfoundState, fromState, fromParams){     console.log(unfoundState.to); // "lazy.state"    console.log(unfoundState.toParams); // {a:1, b:2}    console.log(unfoundState.options); // {inherit:false} + default options})//状态改变成功之后触发    $rootScope.$on('$stateChangeSuccess', function(event, toState, toParams, fromState, fromParams){ ... })    $rootScope.$on('$stateChangeError', function(event, toState, toParams, fromState, fromParams, error){ ... })

view事件

    View被加载但是DOM树构建之前时:     $scope.$on('$viewContentLoading', function(event, viewConfig){ ... });     View被加载而且DOM树构建完成时:     $scope.$on('$viewContentLoaded', function(event){ ... }); 

另一种传参方式

    $state.go('sousuo.dtssjg', {topic : $scope.keyWord}, {reload : true});    由于html中无法动态绑定ui-sref中的路径,可以在控制器中通过state来做跳转

路由中的其他配额

    templateProvider:返回HTML字符串的函数     $stateProvider.state(‘blog.detail', {    templateProvider: function ($timeout, $stateParams) {      return $timeout(function () {        return '<h1 id="stateParams-blogID">' + $stateParams.blogID + '</h1>'      }, 100);    }  })  //以下几个项目中并没有进行配置,而是将功能分化到对控制器和指令中,具体功能也不太理解。可参照官方文档:https://github.com/angular-ui/ui-router/wiki  controller、controllerProvider:指定任何已经被注册的控制器或者一个作为控制器的函数   resolve:在路由到达前预载入一系列依赖或者数据,然后注入到控制器中。   data:数据不会被注入到控制器中,用途是从父状态传递数据到子状态。   onEnter/onExit:进入或者离开当前状态的视图时会调用这两个函数 关于angulsrjs入门介绍,可参阅这篇博文:http://www.zouyesheng.com/angular.html#toc66

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
超越HTML:网络开发的基本技术超越HTML:网络开发的基本技术Apr 26, 2025 am 12:04 AM

要构建一个功能强大且用户体验良好的网站,仅靠HTML是不够的,还需要以下技术:JavaScript赋予网页动态和交互性,通过操作DOM实现实时变化。CSS负责网页的样式和布局,提升美观度和用户体验。现代框架和库如React、Vue.js和Angular,提高开发效率和代码组织结构。

HTML中的布尔属性是什么?举一些例子。HTML中的布尔属性是什么?举一些例子。Apr 25, 2025 am 12:01 AM

布尔属性是HTML中的特殊属性,不需要值即可激活。1.布尔属性通过存在与否控制元素行为,如disabled禁用输入框。2.它们的工作原理是浏览器解析时根据属性的存在改变元素行为。3.基本用法是直接添加属性,高级用法可通过JavaScript动态控制。4.常见错误是误以为需要设置值,正确写法应简洁。5.最佳实践是保持代码简洁,合理使用布尔属性以优化网页性能和用户体验。

如何验证您的HTML代码?如何验证您的HTML代码?Apr 24, 2025 am 12:04 AM

HTML代码可以通过在线验证器、集成工具和自动化流程来确保其清洁度。1)使用W3CMarkupValidationService在线验证HTML代码。2)在VisualStudioCode中安装并配置HTMLHint扩展进行实时验证。3)利用HTMLTidy在构建流程中自动验证和清理HTML文件。

HTML与CSS和JavaScript:比较Web技术HTML与CSS和JavaScript:比较Web技术Apr 23, 2025 am 12:05 AM

HTML、CSS和JavaScript是构建现代网页的核心技术:1.HTML定义网页结构,2.CSS负责网页外观,3.JavaScript提供网页动态和交互性,它们共同作用,打造出用户体验良好的网站。

HTML作为标记语言:其功能和目的HTML作为标记语言:其功能和目的Apr 22, 2025 am 12:02 AM

HTML的功能是定义网页的结构和内容,其目的在于提供一种标准化的方式来展示信息。1)HTML通过标签和属性组织网页的各个部分,如标题和段落。2)它支持内容与表现分离,提升维护效率。3)HTML具有可扩展性,允许自定义标签增强SEO。

HTML,CSS和JavaScript的未来:网络开发趋势HTML,CSS和JavaScript的未来:网络开发趋势Apr 19, 2025 am 12:02 AM

HTML的未来趋势是语义化和Web组件,CSS的未来趋势是CSS-in-JS和CSSHoudini,JavaScript的未来趋势是WebAssembly和Serverless。1.HTML的语义化提高可访问性和SEO效果,Web组件提升开发效率但需注意浏览器兼容性。2.CSS-in-JS增强样式管理灵活性但可能增大文件体积,CSSHoudini允许直接操作CSS渲染。3.WebAssembly优化浏览器应用性能但学习曲线陡,Serverless简化开发但需优化冷启动问题。

HTML:结构,CSS:样式,JavaScript:行为HTML:结构,CSS:样式,JavaScript:行为Apr 18, 2025 am 12:09 AM

HTML、CSS和JavaScript在Web开发中的作用分别是:1.HTML定义网页结构,2.CSS控制网页样式,3.JavaScript添加动态行为。它们共同构建了现代网站的框架、美观和交互性。

HTML的未来:网络设计的发展和趋势HTML的未来:网络设计的发展和趋势Apr 17, 2025 am 12:12 AM

HTML的未来充满了无限可能。1)新功能和标准将包括更多的语义化标签和WebComponents的普及。2)网页设计趋势将继续向响应式和无障碍设计发展。3)性能优化将通过响应式图片加载和延迟加载技术提升用户体验。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中