Ionic/Angularjs 知识点解析
Ionic/Angularjs 知识点解析
angular-ui-router(状态跳转)
state的定义:(在app.js的config下配置)
$stateProvider
.state('app', {
url: '/app',
abstract: true,
templateUrl: 'app/menu.html',
controller: 'AppCtrl'
})
//state 跳转使用该参数名
.state('app.myapp-home', {
//使用href跳转使用该参数 格式为: ( #该参数 )
url: "/myapp/home",
views: {
'menuContent': {
templateUrl: "app/myapp/myapp-home.html",
controller: 'myappHomeCtrl'
}
}
跳转
- 使用js跳转
$state.go('app.myapp-home') - 在UI里使用href属性:
href="#/myapp/home" - state 跟url使用同一个标识,可以减少使用时的混乱
事件阻断
ng-click="questionValueClick(item,$event)"
$scope.questionValueClick = function(item,$event){
$event.stopPropagation();
//do something
}
$rootScope (全局变量缓存)
$rootScope.currentDate = new Date();
{{$root.currentDate}}
ng-repeat (重复绘制内容)
controller的配置
angular.module('app.controllers')
.controller('ExpectCtrl', ['$scope','ExpectService',function($scope,ExpectService) {
//定义好需要用的数据
$scope.data = {};
$scope.data.repectData = ExpectService.getExpectData();
}]);
UI的使用
<div class="list">
<!--使用ng-repeat,定义一个变量 使用in 语句 遍历目标数据列,改标签为循环体,里面的视图将会循环显示-->
<div ng-repeat="expectItem in data.repectData">
<!--使用{{ }}引用循环中的数据-->
<div class="item item-divider">
<span class="expect-label">目标:</span> <span>{{expectItem.title}}</span>
</div>
<a class="item" href="#">
<span class="expect-label">描述:</span> <span>{{expectItem.desc}}</span>
</a>
</div>
</div>
$q (用于返回promise格式的数据)
//定义
function makePromise (){
获取一个deferred
var deferred = $q.defer();
var result = {name:'test'};
//返回一个成功结果
deferred.resolve(result);
//返回一个失败结果
//deferred.reject(result);
return deferred.promise;
}
//调用
makePromise()
//resolve会跳到这里
.then(function(result){
//result 为 {name:'test'}
//do something
})
//reject会跳到这里
.catch(function(result){
//do something
})
localStorage 的使用(本地缓存)
不能保存复杂的对象,所以保存对象要转为json格式
//插入数据
var userMap ={name:'Saber'};
localStorage.setItem('userMap', JSON.stringify(userMap));
//获取数据
var result = JSON.parse(localStorage.getItem('userMap'))
ng-if,ng-show,ng-hide
区别
- ng-if 会直接把元素从dom里面移除
- ng-show,ng-hide 则只是隐藏
- ng-if 相比 ng-show 的性能方面会有很大的优化,当值为 false 的时候,ng-if 内所有绑定都不会执行,而ng-show 内依然会去重新渲染 ng-bind/ng-model。
使用
<a ng-if = "isShowDelete" class="tab-item">
<i class="icon ion-gear-a" ng-click ="showDelete()"></i>删除
</a>
<a ng-show = "isShowDelete" class="tab-item">
<i class="icon ion-gear-a" ng-click ="showDelete()"></i>删除
</a>
<a ng-hide = "isShowDelete" class="tab-item">
<i class="icon ion-gear-a" ng-click ="showDelete()"></i>删除
</a>
ng-class(动态加载 class )
注意有最外面要有{}
<button class="button button-icon button-clear "
ng-class="{'ion-android-arrow-dropdown':data.tplType =='PIC','ion-plus-round':data.tplType =='NOTE'}">
</button>
ng-model(双向绑定 使UI即时刷新)
注意model不要使用简单类型,否则会出现断层(用data封装一下)
<textarea placeholder="Note" class="common-text" ng-model="data.newNote.desc"></textarea>
ng-include(实现界面局部切换)
<div ng-include="template"></div>
//ng-include:的属性应该为template的url,其根目录为 www
$scope.template = 'app/myapp/temp/temp-product-detail.html';
Ionic/Angularjs 知识点解析的更多相关文章
- Cordova Ionic AngularJS
实践分享:开始用Cordova+Ionic+AngularJS开发App http://www.cocoachina.com/webapp/20150707/12395.html
- Ionic 常用组件解析
Ionic 常用组件解析 $ionicModal(弹出窗口): //创建一个窗口 //此处注意目录的起始位置为app $ionicModal.fromTemplateUrl('app/security ...
- ionic项目结构解析
ionic项目结构解析 原始结构 创建一个IonicDemo项目 'ionic start IonicDemo sidemenu' 这种结构多模块开发比较麻烦,因为view跟controller分开路 ...
- 知名互联网公司校招 Java 开发岗面试知识点解析
天之道,损有余而补不足,是故虚胜实,不足胜有余. 本文作者在一年之内参加过多场面试,应聘岗位均为 Java 开发方向.在不断的面试中,分类总结了 Java 开发岗位面试中的一些知识点. 主要包括以下几 ...
- Java 面试知识点解析(一)——基础知识篇
前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...
- Java 面试知识点解析(二)——高并发编程篇
前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...
- Java 面试知识点解析(三)——JVM篇
前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...
- Java 面试知识点解析(四)——版本特性篇
前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...
- Java 面试知识点解析(五)——网络协议篇
前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...
随机推荐
- B507实验室打印机连接方法
一.准备工具 实验室打印机内网IP地址:172.16.135.41 ,这个地址要看具体的打印机地址(可能会更换). 从实验室QQ群(土匪窝)上下载打印机驱动,如下图所示. 3. 非常重要的事情:请链接 ...
- bootstrap学习笔记之基础导航条 http://www.imooc.com/code/3111
基础导航条 在Bootstrap框中,导航条和导航从外观上差别不是太多,但在实际使用中导航条要比导航复杂得多.我们先来看导航条中最基础的一个--基础导航条. 使用方法: 在制作一个基础导航条时,主要分 ...
- javaWeb学习总结(1)- Tomcat服务器学习和使用(3)
一.打包JavaWeb应用 在Java中,使用"jar"命令来对将JavaWeb应用打包成一个War包,jar命令的用法如下:
- 开涛spring3(4.2) - 资源 之 4.2 内置Resource实现
4.2 内置Resource实现 4.2.1 ByteArrayResource ByteArrayResource代表byte[]数组资源,对于“getInputStream”操作将返回一个By ...
- 开涛spring3(2.3) - IoC的配置使用
2.3.1 XML配置的结构 一般配置文件结构如下: <beans> <import resource=”resource1.xml”/> <bean id=”bean ...
- Python字符处理
字符串就是一系列字符.在python中,用引号括起来的都是字符串,这里的引号可以是单引号也可以双引号. 例如: >>> 'this is a string' 'this is a s ...
- Jmeter Boss系统login
之前说,想学习并且掌握自动化测试,但是,折腾过来折腾过去,逐渐意识到了,app自动化测试分为UI层面还有接口测试.(其实,功能测试就是UI+接口测试的集合,当然,只是我自己这么认为,hhhhhhh) ...
- java基础之数组常用操作
常用的对数组进行的操作 1.求数组中最大值,最小值 思路:假设下标为0的元素是最大值,遍历数组,依次跟max进行比较,如果有元素比这个max还大,则把这个值赋给max.最小值同样 public cla ...
- webApi签名验证
还是一如既往先上结构图如下: 上一讲说明了redis,也谢谢心态的建议.这里经过改进后的redis的地址 当然这里是加密了的,具体实现如下图: 这里提供的解密. 先把加密解密的帮助类放上来. usin ...
- Nmap绕过防火墙&脚本的使用
Nmap是用于端口扫描,服务检测,甚至是漏洞扫描等多种功能的强大工具.Nmap从入门到高级覆盖了许多基础的概念和命令,在这篇文章的第二部分,我将提及Nmap一些高级的技术. 防火墙和入侵检测系统(ID ...