IOS开发-文件管理(二)
五、Plist文件
String方式添加
NSString *path = [NSHomeDirectory( ) stringByAppendingPathComponent:@"Array.plist"]; ...
五、Plist文件
String方式添加
NSString *path = [NSHomeDirectory( ) stringByAppendingPathComponent:@"Array.plist"];
NSString *content = @"abcd";
[contect writeToFile:path atomically:YES encoding:NSUTF8StringEncoding error:nil];
Array方式添加
NSString *path = [NSHomeDirectory( ) stringByAppendingPathComponent:@"Array.plist"];
[NSArray *array = [[NSArray alloc] initWithObjects:@"123", @"798",@"000",nil]; [array writeToFile:path atomically:YES];
Dictionary方式添加
NSString *path = [NSHomeDirectory( ) stringByAppendingPathComponent:@"Dic.plist"];
NSDictionary *dic = [NSDictionary alloc] initWithObjects:@"first",@"second",@"third"forKeys:@"123",@"456",@"798"]; [dic writeToFile:path atomically:YES];
数组、字典只能将BOOL、NSNumber、NSString、NSData、NSDate、NSArray、NSDictionary写入属性列表plist文件
六、读取文件类和常用方法
NSFileHandle类主要对文件内容进行读取和写入操作
NSFileManager类主要对文件的操作(删除、修改、移动、复制等等)
常用处理方法
+ (id)fileHandleForReadingAtPath:(NSString *)path 打开一个文件准备读取
+ (id)fileHandleForWritingAtPath:(NSString *)path 打开一个文件准备写入
+ (id)fileHandleForUpdatingAtPath:(NSString *)path 打开一个文件准备更新
- (NSData *)availableData; 从设备或通道返回可用的数据
- (NSData *)readDataToEndOfFile; 从当前的节点读取到文件的末尾
- (NSData *)readDataOfLength:(NSUInteger)length; 从当前节点开始读取指定的长度数据
- (void)writeData:(NSData *)data; 写入数据
- (unsigned long long)offsetInFile; 获取当前文件的偏移量
- (void)seekToFileOffset:(unsigned long long)offset; 跳到指定文件的偏移量
- (unsigned long long)seekToEndOfFile; 跳到文件末尾
- (void)truncateFileAtOffset:(unsigned long long)offset; 将文件的长度设为offset字节
- (void)closeFile; 关闭文件
向文件追加数据
NSString *homePath = NSHomeDirectory( );
NSString *sourcePath = [homePath stringByAppendingPathConmpone:@"testfile.text"];
NSFileHandle *fielHandle = [NSFileHandle fileHandleForUpdatingAtPath:sourcePath];
[fileHandle seekToEndOfFile]; 将节点跳到文件的末尾
NSString *str = @"追加的数据"
NSData* stringData = [str dataUsingEncoding:NSUTF8StringEncoding];
[fileHandle writeData:stringData]; 追加写入数据
[fileHandle closeFile];
定位数据
NSFileManager *fm = [NSFileManager defaultManager];
NSString *content = @"abcdef";
[fm createFileAtPath:path contents:[content dataUsingEncoding:NSUTF8StringEncoding] attributes:nil];
NSFileHandle *fileHandle = [NSFileHandle fileHandleForReadingAtPath:path];
NSUInteger length = [fileHandle availabelData] length]; 获取数据长度
[fileHandle seekToFileOffset;length/2]; 偏移量文件的一半
NSData *data = [fileHandle readDataToEndOfFile];
[fileHandle closeFile];
复制文件
NSFileHandle *infile, *outfile; 输入文件、输出文件
NSData *buffer; 读取的缓冲数据
NSFileManager *fileManager = [NSFileManager defaultManager];
NSString *homePath = NSHomeDirectory( );
NSString *sourcePath = [homePath stringByAppendingPathComponent:@"testfile.txt"]; 源文件路径
NSString *outPath = [homePath stringByAppendingPathComponent:@"outfile.txt"]; 输出文件路径
BOOL sucess = [fileManager createFileAtPath:outPath contents:nil attributes:nil];
if (!success)
{
return N0;
}
infile = [NSFileHandle fileHandleForReadingAtPath:sourcePath]; 创建读取源路径文件
if (infile == nil)
{
return NO;
}
outfile = [NSFileHandle fileHandleForReadingAtPath:outPath]; 创建病打开要输出的文件
if (outfile == nil)
{
return NO;
}
[outfile truncateFileAtOffset:0]; 将输出文件的长度设为0
buffer = [infile readDataToEndOfFile]; 读取数据
[outfile writeData:buffer]; 写入输入
[infile closeFile]; 关闭写入、输入文件
[outfile closeFile];
黑马程序员 Object-c相互导入的问题
在编写Object-c语言的时候,可能会出现相互导入的问题,所谓的相互导入就是两个彼此都#import了对方,例如下面的两个类
在Classes类中#import了Student
#import <Foundation/Foundation.h>
#import "Student.h"
@interface Classes : NSObject{
Student * str;
}
@end
而在Student类中也#import了Classes类
#import <Foundation/Foundation...
在编写Object-c语言的时候,可能会出现相互导入的问题,所谓的相互导入就是两个彼此都#import了对方,例如下面的两个类
在Classes类中#import了Student
#import <Foundation/Foundation.h>
#import "Student.h"
@interface Classes : NSObject{
Student * str;
}
@end
而在Student类中也#import了Classes类
#import <Foundation/Foundation.h>
#import "Classes.h"
@interface Student : NSObject{
Classes *cla;
}
@end
这时再编译的时候就会报错,xcode5报出的错是Unkown type name "Student/Classes"
解决的方法是
其中一个类使用@class关键字来代替#import,在这里解释一下两个关键字的区别
#import 导入一个头文件,获取该头文件中类的定义——方法和属性
@class 告述编译器有这么一个类,但是具体是怎么定义的则不知道
这样又会造成一个问题,因为@class只是告述编译器有这么一个类,解决.h文件的相互导入的问题,但是在.m文件中如果想使用该类的定义的方法或属性,却用不了,没有提示
解决的方法是在.m再使用#import导入需要使用类,这样就不会有问题了。
需要注意的是@class 的后面需要加 ;号,例如 @class Student;
IOS和Javascript的通信(二)
使用Javascript调用ObjectiveC不像ObjectiveC调用Javascript那么简单。需要两方定义协议,按照约定进行对应逻辑的运行。
依然是上一篇文章的代码。当然,如果只是看Javascript如何调用ObjectiveC也可以直接看。html 代码:
<input type = "button" onclick = "javascript_call_objectiveC('startCamera','...
使用Javascript调用ObjectiveC不像ObjectiveC调用Javascript那么简单。需要两方定义协议,按照约定进行对应逻辑的运行。
依然是上一篇文章的代码。当然,如果只是看Javascript如何调用ObjectiveC也可以直接看。html 代码:
<input type = "button" onclick = "javascript_call_objectiveC('startCamera','')" value = "测试" name = "name"/>
Javascript 代码:
function javascript_call_objectiveC(method,parameter) {
var url = "JSCommunicateOC://"+method+":"+parameter;
document.location = url;
}
上面的代码的意思很简单,就是点击测试按钮的时候,调用Javascript的javascript_call_objectiveC方法,Javascript方法定向到一个url地址。在IOS中,当UIWebview中有链接地址跳转的时候,会调用delegate中的
-(BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
方法。在这个方法中你可以通过下面的代码得到请求的url地址:
NSString *requestString = [[[request URL] absoluteString] stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
在这里,当你点击测试按钮的时候,你得到的requestString类似下面这样:
jscommunicateoc://startCamera
已经得到了传过来的请求。至于应该怎么做就是逻辑的事情了。在实际开发中,协议怎么定义,数据怎么解析,都是自己的事情了。当然你自己定义的协议头不应该是标准的协议头,比如HTTP,HTTPs等。
Objective-C和Javascript的通信(三)
(一)Objective-C调用Javascript
把之前的代码:
[webView stringByEvaluatingJavaScriptFromString:@"objectiveC_call_javaScript('调用Javascript');"];
换成下面这样:
JSContext *context = [webView valueForKeyPath:@"...
(一)Objective-C调用Javascript
把之前的代码:
[webView stringByEvaluatingJavaScriptFromString:@"objectiveC_call_javaScript('调用Javascript');"];
换成下面这样:
JSContext *context = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
[context evaluateScript:@"objectiveC_call_javaScript('调用Javascript')"];
运行。得到和之前一样的效果。
(二)Javascript调用Objective-C
IOS 7 以后,Javascript调用Objective-C和以前的方式差别相对比较大。你可以根据你的实际情况,在页面加载完成之前或者页面加载完成之后进行调用。
这里以点击按钮进行Objective-C的调用为例子。因为,一般要在页面加载完成之后才会点击按钮,所以,我们在网页加载完成之后给Javascript提交调用的入口。首先,我们修改点击按钮的响应事件如下:
<input type = "button" onclick = "openCamera()" value = "测试" name = "name"/>
然后在
-(void)webViewDidFinishLoad:(UIWebView *)webView
方法中添加以下代码:
context[@"openCamera"] = ^{
NSLog(@"打开照相机");
};
现在,你点击按钮,就会打印
打开照相机
调用成功。
如果你要在调用方法时传递参数也是很简单的。类似下面这样就可以了:
^(NSString *string ,JSValue *value){
NSLog(@"打开照相机");
};