Titanium.App.Properties是用来管理键值对数据的一个很方便的对象。在保存数据的时候,在Ti.App.Properties.setString相对应的Key的值中设置你要保存的值即可。相反,取值的时候,通过Ti.App.Properties.getString方法,取得你想取的Key的值。setString和getString是设置字符串的方法,类似的还有其他数据类型的方法。特别要说的是,要想原封不动的保存JavaScript对象是不可以的,你需要先通过JSON等处理,将对象序列化后再保存。
 
例如1-----------字符串键值对
 
win.addEventListener(
  'close',
  function(){
      var text = textArea.value;
      Ti.App.Properties.setString('previousText', text);
  }
);
 
win.addEventListener(
  'open',
  function(){
      var text = Ti.App.Properties.getString('previousText');
      if ( text ) {
          textArea.value = text;
      }
  }
);
在window关闭的时候,window中的textarea等UI控件输入的内容将会消失,所以我们在window的close事件中追加监听事件,将输入的数据进行保存。这样,即使应用终了后,编辑中的内容还能够在下次再编辑。
 
例如2-----------列表键值对
win.addEventListener(
  'close',
  function(){
      var text = textArea.value;
      Ti.App.Properties.setString('previousText', text);
 
      if (mapview.visible) {
          var loc = mapview.location;
          var locationList =
              [loc.latitude,loc.longitude,loc.latitudeDelta,loc.longitudeDelta];
          Ti.App.Properties.setList('locationList', locationList);
      }
  }
);
 
win.addEventListener(
  'open',
  function(){
      var text = Ti.App.Properties.getString('previousText');
      if ( text ) {
          textArea.value = text;
      }
      if ( Ti.App.Properties.hasProperty('locationList') ) {
          var locationList = Ti.App.Properties.getList('locationList');
          mapview.show();
          mapview.setLocation(
              {
                  latitude : locationList[0],
                  longitude : locationList[1],
                  latitudeDelta : locationList[2],
                  longitudeDelta : locationList[3]
              }
          );
      }
  }
);
在这个例子中,mapview中要设置的4个关于位置的信息值,能够将其变化成数据后保存起来。原封不动保存对象是不可以的,但是如果有很多值的话,你可以其以数组的形式保存。 
当我们要判断某个Key中是否有值的时候,可以使用Ti.App.Properties.hasProperty。
 
 
3----文件操作
在上边的例子中,我们通过使用Ti.App.Properties来保存了数据。在Titanium中也能够很方便的读写文件。以下通过例子来说明如何将数据保存到文件中:
Js代码
var fileName = 'tweet.txt';
win.addEventListener(
  'close',
  function(){
      var text = textArea.value;
      var loc;
      if (mapview.visible) {
          loc = mapview.location;
      }
      var json = JSON.stringify({previousText:text,location:loc});
      var file  = Ti.Filesystem.getFile(
          Titanium.Filesystem.resourcesDirectory + '/' + fileName
      );
      file.write(json);
  }
);
 
win.addEventListener(
  'open',
  function(){
      var file  = Ti.Filesystem.getFile(
          Titanium.Filesystem.resourcesDirectory + '/' + fileName
      );
      var json = file.read();
      if ( !json || json.length <= 0) {
          return;
      }
      var data = JSON.parse(json);
      var text = data.previousText;
      var location = data.location;
      if ( text ) {
          textArea.value = text;
      }
      if ( location ) {
          var locationList = Ti.App.Properties.getList('locationList');
          mapview.show();
          mapview.setLocation(location);
      }
  }
);
在写文件的时候需要注意的一点是:获取文件句柄的方法是Titanium.Filesystem.getFile。
其中的参数就是文件的路径。
Js代码 
1. Titanium.Filesystem.resourcesDirectory + '/' + fileName 
 
这里我们通过resourcesDirectory来指定文件路径,相应的其他的可读写路径,Titanium也提供了很多种,大家可以查查API。
 
在往文件中写入对象的数据的话也一样要通过JSON来序列化。
 
Titanium中已经为我们提供了JSON的序列化(stringify)和反序列化(parse)方法。上边的例子中大家可以看到具体的用法。
 
图像的保存
 
在Tweet的编辑页面中,我们还表示了一个图像,到现在为止,我们都是通过从相册中选择出来的图片,所以图片本身就保存在相册中,但是当我们通过相机拍照的话,就需要将图片保存在相册中。
Js代码 
1. Titanium.Media.saveToPhotoGallery(image) 
 
通过以上代码就能将image图片保存到相册中。
 
Js代码 
1. var file  = Ti.Filesystem.getFile( 
2.    Titanium.Filesystem.resourcesDirectory + '/' + fileName
3. ); 
4. file.write(image) 
 
当然也可以通过这样的方法,将图像以文件的形式保存。

Titanium.App.Properties 对象的更多相关文章

  1. 为什么在使用get时,Properties对象总是忽略默认值?

    不应该对Properties对象调用get方法:而应该调用getProperty方法.许多人认为二者的区别是getProperty声明了返回值为String类型,而get声明的返回值类型为Object ...

  2. Java IO(Properties/对象序列化/打印流/commons-io)

    Java IO(Properties/对象序列化/打印流/commons-io) Properties Properties 类表示了一个持久的属性集.Properties 可保存在流中或从流中加载. ...

  3. spring中配置Properties对象的方法

    工作中有必要将Properties对象进行注解进入:比如 class Person{ @Autowired private Properties properties; } 如果有这种需求的话,那么需 ...

  4. Vue中app实例对象的几种写法

    1.传统方法(练习 小DEMO中用的这种) <script type="text/ecmascript"> var app=new Vue({ el:"#ap ...

  5. DI,依赖注入,给对象赋值 ,get,set,list,set,map,properties对象赋值

  6. java IO之 序列流 集合对象Properties 打印流 流对象

    序列流 也称为合并流. SequenceInputStream 序列流,对多个流进行合并. SequenceInputStream 表示其他输入流的逻辑串联.它从输入流的有序集合开始,并从 第一个输入 ...

  7. spring框架是怎么样通过properties来获得对象的?

    首先我们要知道java获得对象的方式有四种: 1.通过new语句实例化一个对象. 2.通过反射机制创建对象. 3.通过clone()方法创建对象 3.通过反序列化的方式创建对象 在spring框架中, ...

  8. ServletContext对象--三大域对象

    Servlet三大域对象的应用 request.session.application(ServletContext) ServletContext是一个全局的储存信息的空间,服务器开始就存在,服务器 ...

  9. (七)SpringBoot2.0基础篇- application.properties属性文件的解析及获取

    默认访问的属性文件为application.properties文件,可在启动项目参数中指定spring.config.location的参数: java -jar myproject.jar --s ...

随机推荐

  1. Oracle 用Drapper进行like模糊传参查询需要在参数值前后带%符合

    Oracle 用Drapper进行like模糊传参查询需要在参数值前后带%符合   string sqlstr="select * from tblname where name like ...

  2. 基于AngularJs的上传控件-angular-file-upload

    今天跟大家分享的是一个依赖于angular的上传控件. 前段时间做项目遇到一个需求是上传文件,大概需要实现的样式是这样子的,见下图: 需要同时上传两个文件.并且规定文件格式和文件大小.因为前端框架使用 ...

  3. 从零开始,DIY一个jQuery(2)

    在上篇文章我们简单实现了一个 jQuery 的基础结构,不过为了顺应潮流,这次咱把它改为模块化的写法,此举得以有效提升项目的可维护性,因此在后续也将以模块化形式进行持续开发. 模块化开发和编译需要用上 ...

  4. WinRT自定义控件第一 - 转盘按钮控件

    之前的文章中,介绍了用WPF做一个转盘按钮控件,后来需要把这个控件移植到WinRT时,遇到了很大的问题,主要原因在于WPF和WinRT还是有很大不同的.这篇文章介绍了这个移植过程,由于2次实现的控件功 ...

  5. 论C#逼格手册

    水文.如何让自己的代码看起来,更有逼格? 要想让自己的代码,看起来更优雅,更有逼格,更高大上,就一定要写出晦涩难懂,而又简洁的代码来. 对于类自身的全局变量,一定要加this,对于基类的,一定要加ba ...

  6. ABP源码分析三十三:ABP.Web

    ABP.Web模块并不复杂,主要完成ABP系统的初始化和一些基础功能的实现. AbpWebApplication : 继承自ASP.Net的HttpApplication类,主要完成下面三件事一,在A ...

  7. AngularJs之六(服务)

    服务:AngularJS 中,服务是一个函数或对象,可在你的 AngularJS 应用中使用.AngularJS 内建了30 多个服务. 最常用的服务:$location  服务,  $http 服务 ...

  8. div里嵌套了img 底部会出现白边

    因为img默认是按基线(baseline)对齐的.对比一下图片和右边的p, q, y等字母,你会发现这三个字母的“小尾巴”和图片下方的空白一样高.下面这张图中的黑线就是那条基线. 要去掉空格可以使用v ...

  9. 通过easyui tab添加的子页面JS脚本必须放在body才生效

    通过easyui tab添加的子页面JS脚本必须放在body才生效 可通过Chrome查看元素时,head标签是否含有你自己写的JS代码

  10. HTML5_04之SVG绘图

    1.关于Canvas绘制图像: 问题:需要绘制多张图片时,必须等待所有图片加载完成才能开始绘制:而每张图片都是异步请求,彼此没有先后顺序,哪一张先加载完成完全无法预测: 方案: var progres ...