用Trigger.io改进移动Angular.js应用

简介: 版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/42107669 用Trigger.io改进移动Angular.js应用作者:chszs,转载需注明。
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/42107669

用Trigger.io改进移动Angular.js应用

作者:chszs,转载需注明。博客主页:http://blog.csdn.net/chszs

Trigger.io Forge可以让我们使用最新、最好的Web技术来开发本地移动应用。
本文展示了开发一个简单的Angular.js应用示例,并使用Forge模块增强此应用,包括:
1)使用forge.prefs来增加离线能力和持久化能力
2)使用forge.topbar来增加本地topbar和动作按钮
3)使用forge.tabbar来实现视图间的导航

本示例是做一个TODO列表。

一、创建一个Forge应用

第一步是创建一个Forge应用,要确保APP可以离线运行,我们必须在本地包含angular.min.js和bootstrap.css文件。运行代码后可以看到上面的界面。
整个应用的结构如下:

index.html的内容:

<!doctype html>
<html ng-app>
	<head>
		<script src="js/angular-1.0.1.min.js"></script>
		<script src="js/todo.js"></script>
		<link rel="stylesheet" href="css/bootstrap.css">
		<style>
			.done-true {
				text-decoration: line-through;
				color: grey;
			}
		</style>
	</head>
	<body>
		<h2>Todo</h2>
		<div ng-controller="TodoCtrl">
			<span>{{remaining()}} of {{todos.length}} remaining</span>
			[ <a href="" ng-click="archive()">archive</a> ]
			<ul class="unstyled">
				<li ng-repeat="todo in todos">
					<input type="checkbox" ng-model="todo.done">
					<span class="done-{{todo.done}}">{{todo.text}}</span>
				</li>
			</ul>
			<form ng-submit="addTodo()">
				<input type="text" ng-model="todoText"	size="30"
							 placeholder="add new todo here">
				<input class="btn-primary" type="submit" value="add">
			</form>
		</div>
	</body>
</html>

二、持久化数据

现在HTML5示例的程序已经完成,那么我们可以使用Forge的扩展功能来改进此应用。
我们要做的第一件事是使用prefs模块来持久化TODO列表。无论TODO列表是否得到更新,都需要保存它。代码如下:
forge.prefs.set(“todos”, $scope.todos);


当APP运行时,就可以用存储的TODO列表数据恢复TODO列表了。

// 用存储的数据恢复TODO列表
forge.prefs.get("todos", function(todos{
	// 更新Angular模型, $apply确保视图得到更新
	$scope.$apply(function(){
		if(todos){
			$scope.todos = todos;
		} else{
			$scope.todos = [
				{text:'learn angular', done:true},
				{text:'build an angular app', done:false},
				{text:'extend angular app to work with Forge', done:false}
			];
		}
	});
}));
要注意的是这块代码$scope.$apply(function () { ... }),它告诉Angular,此代码块会修改模型,代码运行后视图应该得到更新。没有这块代码,一旦prefs被载入后,用户是看不到更新的。

三、添加一个topbar

我们还可以为APP的界面添加一个topbar,即使TODO列表太长,导致页面卷边,topbar也总是可见的。要做到这一点,我们可以把index.html的内容<h2>Todo</h2>删除,添加topbar模块。

topbar模块允许我们添加按钮事件,我们可以在页面上移除存档的链接,还可以添加本地按钮来存档已完成的任务。代码如下:

forge.topbar.addButton({
	icon: "img/accept.png"
}, function(){
	$scope.$apply($scope.archive);
});
四、添加一个tabbar

如同topbar一样,我们还可以使用Forge添加一个本地tabbar。借此,我们将第二页添加到TODO列表应用中,这页的功能是允许用户查看以前归档的任务。
要做到这一点,我们添加一些HTML代码以及几个JavaScript函数来实现两页之间的切换,TODO列表的持久化仍旧使用prefs实现。代码如下:

// 添加Forge tabbar按钮
forge.tabbar.addButton({
	icon: "img/list.png",
	text: "Todo list"
}, function(button){
	button.setActive();
	button.onPressed.addListener(function(){
		$scope.$apply($scope.showList);
	});
});
forge.tabbar.addButton({
	icon: "img/archive.png",
	text: "Archive"
}, function(button){
	button.onPressed.addListener(function(){
		$scope.$apply($scope.showArchive);
	});
})
五、总结

我们现在有了一个简单的TODO列表应用,在Forge运行,并同时利用了Angular.js和Forge模块的优点,还允许访问本地特性,并同时支持Android和iOS的运行。

  

完整的源码在GitHub,见:https://github.com/Connorhd/Forge-Angular-Todo

目录
相关文章
|
1月前
|
开发框架 前端开发 JavaScript
使用JavaScript、jQuery和Bootstrap构建待办事项应用
使用JavaScript、jQuery和Bootstrap构建待办事项应用
13 0
|
1月前
|
自然语言处理 JavaScript 前端开发
探索JavaScript中的闭包:理解其原理与实际应用
探索JavaScript中的闭包:理解其原理与实际应用
19 0
|
1月前
|
JavaScript 前端开发 算法
js开发:请解释什么是虚拟DOM(virtual DOM),以及它在React中的应用。
虚拟DOM是React等前端框架的关键技术,它以轻量级JavaScript对象树形式抽象表示实际DOM。当状态改变,React不直接操作DOM,而是先构建新虚拟DOM树。通过高效diff算法比较新旧树,找到最小变更集,仅更新必要部分,提高DOM操作效率,降低性能损耗。虚拟DOM的抽象特性还支持跨平台应用,如React Native。总之,虚拟DOM优化了状态变化时的DOM更新,提升性能和用户体验。
24 0
|
19天前
|
存储 JavaScript 前端开发
Angular 应用 node_modules 子文件夹 @types 的作用介绍
Angular 应用 node_modules 子文件夹 @types 的作用介绍
12 1
|
11天前
|
开发框架 前端开发 JavaScript
采用C#.Net +JavaScript 开发的云LIS系统源码 二级医院应用案例有演示
技术架构:Asp.NET CORE 3.1 MVC + SQLserver + Redis等 开发语言:C# 6.0、JavaScript 前端框架:JQuery、EasyUI、Bootstrap 后端框架:MVC、SQLSugar等 数 据 库:SQLserver 2012
|
30天前
|
开发框架 JavaScript 前端开发
描述JavaScript事件循环机制,并举例说明在游戏循环更新中的应用。
JavaScript的事件循环机制是单线程处理异步操作的关键,由调用栈、事件队列和Web APIs构成。调用栈执行函数,遇到异步操作时交给Web APIs,完成后回调函数进入事件队列。当调用栈空时,事件循环取队列中的任务执行。在游戏开发中,事件循环驱动游戏循环更新,包括输入处理、逻辑更新和渲染。示例代码展示了如何模拟游戏循环,实际开发中常用框架提供更高级别的抽象。
14 1
|
1月前
|
开发框架 前端开发 安全
Angular:构建现代Web应用的终极选择
Angular:构建现代Web应用的终极选择
23 0
|
1月前
|
JavaScript 前端开发
HTML JS 应用
HTML JS 应用
19 3
|
1月前
|
JavaScript 前端开发 算法
Vue.js的单向数据流:让你的应用更清晰、更可控
Vue.js的单向数据流:让你的应用更清晰、更可控
|
1月前
|
JavaScript 前端开发 API
Vue.js 深度解析:nextTick 原理与应用
Vue.js 深度解析:nextTick 原理与应用