【IOS】IOS开发问题解决方法索引(五)

1      Block教程系列

发布者:Seven's 2013/04/22 - 分类:梦印象

ios开发block的使用指南,以及深入理解block的内存管理,也适用于osx开发。

讨论范围:block的使用,内存管理,内部实现。

不包含的内容:gc arc下的block内存,blockc++中的使用。

  1. Block介绍(一)基础
  2. Block介绍(二)内存管理与其他特性
  3. block介绍(三)揭开神秘面纱(上)
  4. block介绍(四)揭开神秘面纱(下)

2      iOS开发 git github 初学+进阶

iOS开发 git github初学+进阶

http://guxiaojje.blog.163.com/blog/static/140942291201272110343064/

 

3      iPhone应用程序的启动过程

 

 

iPhone应用程序的启动过程

http://mobile.51cto.com/iphone-284474.htm

4      使用静态IP无法打开部分网页的解决办法

 

使用静态IP无法打开部分网页的解决办法,手动设置DNS,并且备用DNS设置为114.114.114.114

 

5      js枚举类型

js枚举类型定义:

方法 1:

var DataType = {String1:value1,String2:value2 }

 

      方法 2:

var DataType = { } ;

DataType.String1=value1;

DataType.String2=value2;

遍历枚举类型:

for(var i in DataType ){

DataType[i]; //获取value

i;//下标

 }

 

6      当前无线网络不能勾选“自动发现代理”,不然无法Safari无法联网

 

 

7      xcode编译时报错Permission denied

错误信息;

/Users/huangjun/Library/Developer/Xcode/DerivedData/HJCommonSDK-agizpwqgszletfcizlxijeokyaaq/Build/Intermediates/iPhone.build/Debug-iphonesimulator/iPhone.build/Script-B52D492810DA4041008E8365.sh:line 2: ./Build Scripts/set_version_number.rb: Permission denied

 

 

8       【CoreData】新建记录

ios中的coredata的使用

http://blog.csdn.net/chen505358119/article/details/9334831

 

1.  //插入数据  

2.  - (IBAction)addIntoDataSource:(id)sender {  

3.      User* user=(User *)[NSEntityDescription insertNewObjectForEntityForName:@"User" inManagedObjectContext:self.myAppDelegate.managedObjectContext];  

4.      [user setName:_nameText.text];  

5.      [user setAge:[NSNumber numberWithInteger:[_ageText.text integerValue]]];  

6.      [user setSex:_sexText.text];  

7.      NSError* error;  

8.      BOOL isSaveSuccess=[_myAppDelegate.managedObjectContext save:&error];  

9.      if (!isSaveSuccess) {  

10.         NSLog(@"Error:%@",error);  

11.     }else{  

12.         NSLog(@"Save successful!");  

13.     }  

14.       

15. }  

9       【CoreData】查询记录

1.  //查询  

2.  - (IBAction)query:(id)sender {  

3.      NSFetchRequest* request=[[NSFetchRequest alloc] init];  

4.      NSEntityDescription* user=[NSEntityDescription entityForName:@"User" inManagedObjectContext:_myAppDelegate.managedObjectContext];  

5.      [request setEntity:user];  

6.  //    NSSortDescriptor* sortDescriptor=[[NSSortDescriptor alloc] initWithKey:@"name" ascending:YES];  

7.  //    NSArray* sortDescriptions=[[NSArray alloc] initWithObjects:sortDescriptor, nil];  

8.  //    [request setSortDescriptors:sortDescriptions];  

9.  //    [sortDescriptions release];  

10. //    [sortDescriptor release];  

11.     NSError* error=nil;  

12.     NSMutableArray* mutableFetchResult=[[_myAppDelegate.managedObjectContext executeFetchRequest:request error:&error] mutableCopy];  

13.     if (mutableFetchResult==nil) {  

14.         NSLog(@"Error:%@",error);  

15.     }  

16.     NSLog(@"The count of entry: %i",[mutableFetchResult count]);  

17.     for (User* user in mutableFetchResult) {  

18.         NSLog(@"name:%@----age:%@------sex:%@",user.name,user.age,user.sex);  

19.     }  

20.     [mutableFetchResult release];  

21.     [request release];  

22. }  

10    【CoreData】更新记录

1.  //更新  

2.  - (IBAction)update:(id)sender {  

3.      NSFetchRequest* request=[[NSFetchRequest alloc] init];  

4.      NSEntityDescription* user=[NSEntityDescription entityForName:@"User" inManagedObjectContext:_myAppDelegate.managedObjectContext];  

5.      [request setEntity:user];  

6.      //查询条件  

7.      NSPredicate* predicate=[NSPredicate predicateWithFormat:@"name==%@",@"chen"];  

8.      [request setPredicate:predicate];  

9.      NSError* error=nil;  

10.     NSMutableArray* mutableFetchResult=[[_myAppDelegate.managedObjectContext executeFetchRequest:request error:&error] mutableCopy];  

11.     if (mutableFetchResult==nil) {  

12.         NSLog(@"Error:%@",error);  

13.     }  

14.     NSLog(@"The count of entry: %i",[mutableFetchResult count]);  

15.     //更新age后要进行保存,否则没更新  

16.     for (User* user in mutableFetchResult) {  

17.         [user setAge:[NSNumber numberWithInt:12]];  

18.           

19.     }  

20.     [_myAppDelegate.managedObjectContext save:&error];  

21.     [mutableFetchResult release];  

22.     [request release];  

23.       

24. }  

11    【CoreData】删除记录

1.  //删除  

2.  - (IBAction)del:(id)sender {  

3.      NSFetchRequest* request=[[NSFetchRequest alloc] init];  

4.      NSEntityDescription* user=[NSEntityDescription entityForName:@"User" inManagedObjectContext:_myAppDelegate.managedObjectContext];  

5.      [request setEntity:user];  

6.      NSPredicate* predicate=[NSPredicate predicateWithFormat:@"name==%@",@"chen"];  

7.      [request setPredicate:predicate];  

8.      NSError* error=nil;  

9.      NSMutableArray* mutableFetchResult=[[_myAppDelegate.managedObjectContext executeFetchRequest:request error:&error] mutableCopy];  

10.     if (mutableFetchResult==nil) {  

11.         NSLog(@"Error:%@",error);  

12.     }  

13.     NSLog(@"The count of entry: %i",[mutableFetchResult count]);  

14.     for (User* user in mutableFetchResult) {  

15.         [_myAppDelegate.managedObjectContext deleteObject:user];  

16.     }  

17.       

18.     if ([_myAppDelegate.managedObjectContext save:&error]) {  

19.         NSLog(@"Error:%@,%@",error,[error userInfo]);  

20.     }  

21. }  

 

 

12    【CoreData】多条件查询

predicate = [NSPredicatepredicateWithFormat:@"(salesMan = %@) AND (customerName contains %@) AND(customerSex = %@) AND (createdDate >= %d) AND (createdDate <=%d)",[[NSUserDefaults standardUserDefaults]objectForKey:kDefaultUsernameKey], custName,custSex, fromTime, toTime];

 

13    【CoreData】处理海量数据

BatchUpdates可用于批量快速更新数据Asynchronous Fetching可用于异步抓取海量数据并可以通过 NSProgress 实现进度跟踪和取消

13.1  Batch Updates

CoreData中想要更新大量数据,我们往往要将大量修改后的NSManagedObject 加载到 NSManagedObjectContext 中并保存,这会占用大量内存,试想想在iPhone这样的内存有限的移动设备上将是个灾难,数据有可能丢失。你可能会采取批处理的方式,即一小批一小批的更新 NSManagedObject 并保存到 NSManagedObjectContext 中,但这样会花费很多时间,用户体验较差。

为了解决这个问题,苹果在 NSManagedObjectContext 加入了一个新的方法:executeRequest:error: ,它接受一个 NSPersistentStoreRequest 类型的参数,返回类型为 NSPersistentStoreResult 

关于 NSPersistentStoreRequest 有些人可能比较熟悉,它是NSFetchRequest  NSSaveChangesRequest  NSBatchUpdateRequest NSAsynchronousFetchRequest 的基类。后两个类是这次iOS8新加的,也是这篇文章将要讨论的内容。

NSPersistentStoreResult 是一个新加入的类,它也是一个基类,而且是抽象类,这个类作为 executeRequest:error: 返回内容的父类,相当于一个接口,它目前有两个子类: NSPersistentStoreAsynchronousResult NSBatchUpdateResult 

你大概猜到了, NSBatchUpdateResult 对应着前面的NSBatchUpdateRequest ,下面说说 NSBatchUpdateRequest 。它有点像NSFetchRequest :它允许你指定一个想要更新数据的实体;也可以指定一个affectedStores ,它存储了一个接受更新请求的 NSPersistentStore 数组。(其实它是 NSPersistentStoreRequest 的属性);它也有一个谓词属性来做更新的条件,它跟 NSFetchRequest 中的谓词一样强大和灵活,类似于SQLwhere语句;它允许你指定想要更新的字段,通过 propertiesToUpdate 属性来描述字段更新,它是一个字段,key NSPropertyDescription 或属性名字符串,value NSExpression 或常量。

接着谈谈 NSBatchUpdateResult ,它有一个 result 属性和 resultType属性, result 中的内容跟 resultType 有关,可能是成功或者失败,有可能是每行被更新的ID,也可能是被更新的行数。

需要注意的是,由于 NSBatchUpdateRequest 并不会先将数据存入内存,而是直接操作数据库,所以并不会引起NSManagedObjectContext的同步更新,所以你不仅需要获取 NSBatchUpdateResult 然后刷新 NSManagedObjectContext 对应的数据和UI界面,还需要保证更新后的数据满足数据库模型上的 validation ,因为 NSManagedObjectContext 没有感知Batch Updates,一些数据验证工作就落在了程序员的身上(你需要写一段代码验证更新后的数据是合法的,用户可不希望在跑步APP上看到自己今天跑步里程是个负数)。一旦有非法数据录入数据库,下次加载并修改 NSManagedObject 的时候就会导致数据验证失败。除了上面提到的这些,还要注意Batch Updates对数据库的操作是乐观锁,也就是假定很少会发生同时存取同一块数据的情况,所以你需要制定一个合理的”merge”策略来应付因同时更新数据产生的冲突。

Batch Updates的优势在于其效率,在处理上万条数据的时候,它执行的时间跟SQL语句执行时间相当。

13.2  Asynchronous Fetching

Asynchronous Fetching的加入依然是为了解决CoreData读取海量数据所带来的问题。通过使用Asynchronous Fetching,我们可以在抓取数据的同时不阻塞占用NSManagedObjectContext ,并可以随时取消抓取行为,随时跟踪抓取数据的进度。

设想我们平时用 NSFetchRequest 抓取数据的时候,我们会先用NSManagedObjectContext  executeFetchRequest:error: 方法传入一个NSFetchRequest ,然后请求会被发送到 NSPersistentStore ,然后执行一段时间后返回一个数组,在 NSManagedObjectContext 更新后,这个数组被当做executeFetchRequest:error: 的返回值返回到我们这里。

AsynchronousFetching则不同,当我们将一个NSAsynchronousFetchRequest 对象传入 executeRequest:error: 方法后会立即返回一个未来的” NSAsynchronousFetchResult NSAsynchronousFetchRequest 初始化时需要传入两个参数赋值给属性:

1.   completionBlock 属性允许我们在抓取完成后执行回调block

2.   fetchRequest 属性类型是 NSFetchRequest 也即是说虽然是异步抓取其实我们用的还是以前的 NSFetchRequest  NSFetchRequest 抓取结束后会更新 NSManagedObjectContext 这也就意味着NSManagedObjectContext 的并发类型只能是NSPrivateQueueConcurrencyType  NSMainQueueConcurrencyType

于是当我们用 NSAsynchronousFetchRequest 抓取数据时,我们会先用NSManagedObjectContext  executeRequest:error: 方法传入一个NSAsynchronousFetchRequest ,这个方法在 NSManagedObjectContext 上执行时, NSManagedObjectContext 会立即制造并返回一个NSAsynchronousFetchResult ,同时 NSAsynchronousFetchRequest 会被发送到 NSPersistentStore 。你现在可以继续编辑这个NSManagedObjectContext 中的 NSManagedObject ,等到NSPersistentStore 执行请求完毕时会将结果返回给NSAsynchronousFetchResult  finalResult 属性,更新NSManagedObjectContext ,执行 NSAsynchronousFetchRequest 的回调block

举个栗子:

let request = NSFetchRequest(entityName: "MyEntity")         let async = NSAsynchronousFetchRequest(fetchRequest: request){             (id result) in             if result.finalResult {                 //TODO..             }         }

Swift代码很简洁,并用了尾随闭包语法,看不懂的朋友也不用着急,知道NSAsynchronousFetchRequest 大概的用法就行。

之前提到过 NSAsynchronousFetchRequest 能在抓取数据的过程中跟踪进度,于是乎 NSProgress 登场了!一行代码顶十句话:

let request = NSFetchRequest(entityName: "MyEntity") var asyncResult:NSPersistentStoreResult! let async = NSAsynchronousFetchRequest(fetchRequest: request){             (id result) in             if result.finalResult {                 //TODO..             }         } let progress = NSProgress(totalUnitCount: 1) progress.becomeCurrentWithPendingUnitCount(1) managedObjectContext?.performBlock{             [unowned self] in             let error = NSErrorPointer()             asyncResult = self.managedObjectContext?.executeRequest(async, error: error)         } progress.resignCurrent()

而取消获取数据只需要取消 NSProgress 就可以了!取消行为会沿着数的根节点蔓延到叶子。

progress.cancel()

可以在 cancellationHandler 属性设置取消后执行的block,这里不再多说。

 

14    【NSSet】NSArray NSSet转换

1.  NSArray *arr = @[@"12-11"@"12-11"@"12-11"@"12-12"@"12-13"@"12-14"];  

2.  NSSet *set = [NSSet setWithArray:arr];  

3.  NSLog(@"set%@\n", set);  

 

15    【NSSet】NSSet的排序

1.  NSArray *arr = @[@"12-11"@"12-11"@"12-11"@"12-12"@"12-13"@"12-14"];  

2.  NSSet *set = [NSSet setWithArray:arr];  

3.  NSArray *sortDesc = @[[[NSSortDescriptor alloc] initWithKey:nil ascending:YES]];  

4.  NSArray *sortSetArray = [set sortedArrayUsingDescriptors:sortDesc];  

5.  NSLog(@"set%@\nsort set%@", set, sortSetArray); 

 

16    【JS】位运算的运算符优先级问题

在Javascript中,位运算的运算符优先级比加减号低,所以一定要注意,正确的写法是在位运算符处加上括号:

_deviceStatusData.outflowTDS.value= (body[43] << 8) + body[42];

17    【JS】Js获取当前日期时间及其它操作

varmyDate = new Date();
myDate.getYear();        //
获取当前年份(2)
myDate.getFullYear();    //
获取完整的年份(4,1970-????)
myDate.getMonth();       //
获取当前月份(0-11,0代表1)
myDate.getDate();        //
获取当前日(1-31)
myDate.getDay();         //
获取当前星期X(0-6,0代表星期天)
myDate.getTime();        //
获取当前时间(1970.1.1开始的毫秒数)
myDate.getHours();       //
获取当前小时数(0-23)
myDate.getMinutes();     //
获取当前分钟数(0-59)
myDate.getSeconds();     //
获取当前秒数(0-59)
myDate.getMilliseconds();    //
获取当前毫秒数(0-999)
myDate.toLocaleDateString();     //
获取当前日期
var mytime=myDate.toLocaleTimeString();     //
获取当前时间
myDate.toLocaleString( );        //
获取日期与时间

 

日期时间脚本库方法列表

Date.prototype.isLeapYear判断闰年
Date.prototype.Format
日期格式化
Date.prototype.DateAdd
日期计算
Date.prototype.DateDiff
比较日期差
Date.prototype.toString
日期转字符串
Date.prototype.toArray
日期分割为数组
Date.prototype.DatePart
取日期的部分信息
Date.prototype.MaxDayOfDate
取日期所在月的最大天数
Date.prototype.WeekNumOfYear
判断日期所在年的第几周
StringToDate
字符串转日期型
IsValidDate
验证日期有效性
CheckDateTime
完整日期时间检查
daysBetween
日期天数差

js代码:

//---------------------------------------------------  
//
判断闰年  
//---------------------------------------------------  
Date.prototype.isLeapYear = function()   
{   
    return(0==this.getYear()%4&&((this.getYear()%100!=0)||(this.getYear()%400==0)));   
}   
  
//---------------------------------------------------  
//
日期格式化  
//
格式 YYYY/yyyy/YY/yy 表示年份  
// MM/M
月份  
// W/w
星期  
// dd/DD/d/D
日期  
// hh/HH/h/H
时间  
// mm/m
分钟  
// ss/SS/s/S
  
//---------------------------------------------------  
Date.prototype.Format = function(formatStr)   
{   
    var str = formatStr;   
    var Week = ['
','','','','','',''];  
  
    str=str.replace(/yyyy|YYYY/,this.getFullYear());   
    str=str.replace(/yy|YY/,(this.getYear() % 100)>9?(this.getYear()% 100).toString():'0' + (this.getYear() % 100));   
  
    str=str.replace(/MM/,this.getMonth()>9?this.getMonth().toString():'0'+ this.getMonth());   
    str=str.replace(/M/g,this.getMonth());   
  
    str=str.replace(/w|W/g,Week[this.getDay()]);   
  
    str=str.replace(/dd|DD/,this.getDate()>9?this.getDate().toString():'0'+ this.getDate());   
    str=str.replace(/d|D/g,this.getDate());   
  
    str=str.replace(/hh|HH/,this.getHours()>9?this.getHours().toString():'0'+ this.getHours());   
    str=str.replace(/h|H/g,this.getHours());   
    str=str.replace(/mm/,this.getMinutes()>9?this.getMinutes().toString():'0'+ this.getMinutes());   
    str=str.replace(/m/g,this.getMinutes());   
  
    str=str.replace(/ss|SS/,this.getSeconds()>9?this.getSeconds().toString():'0'+ this.getSeconds());   
    str=str.replace(/s|S/g,this.getSeconds());   
  
    return str;   
}   
  
//+---------------------------------------------------  
//|
求两个时间的天数差日期格式为 YYYY-MM-dd   
//+---------------------------------------------------  
function daysBetween(DateOne,DateTwo)  
{   
    var OneMonth = DateOne.substring(5,DateOne.lastIndexOf('-'));  
    var OneDay =DateOne.substring(DateOne.length,DateOne.lastIndexOf ('-')+1);  
    var OneYear = DateOne.substring(0,DateOne.indexOf('-'));  
  
    var TwoMonth = DateTwo.substring(5,DateTwo.lastIndexOf('-'));  
    var TwoDay =DateTwo.substring(DateTwo.length,DateTwo.lastIndexOf ('-')+1);  
    var TwoYear = DateTwo.substring(0,DateTwo.indexOf('-'));  
  
    var cha=((Date.parse(OneMonth+'/'+OneDay+'/'+OneYear)-Date.parse(TwoMonth+'/'+TwoDay+'/'+TwoYear))/86400000);   
    return Math.abs(cha);  
}  
  
  
//+---------------------------------------------------  
//|
日期计算  
//+---------------------------------------------------  
Date.prototype.DateAdd = function(strInterval, Number) {   
    var dtTmp = this;  
    switch (strInterval) {   
        case 's' :return newDate(Date.parse(dtTmp) + (1000 * Number));  
        case 'n' :return newDate(Date.parse(dtTmp) + (60000 * Number));  
        case 'h' :return newDate(Date.parse(dtTmp) + (3600000 * Number));  
        case 'd' :return newDate(Date.parse(dtTmp) + (86400000 * Number));  
        case 'w' :return newDate(Date.parse(dtTmp) + ((86400000 * 7) * Number));  
        case 'q' :return newDate(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number*3, dtTmp.getDate(),dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());  
        case 'm' :return newDate(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, dtTmp.getDate(),dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());  
        case 'y' :return newDate((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(),dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());  
    }  
}  
  
//+---------------------------------------------------  
//|
比较日期差 dtEnd 格式为日期型或者有效日期格式字符串  
//+---------------------------------------------------  
Date.prototype.DateDiff = function(strInterval, dtEnd) {   
    var dtStart = this;  
    if (typeof dtEnd == 'string' )//
如果是字符串转换为日期型  
    {   
        dtEnd =StringToDate(dtEnd);  
    }  
    switch (strInterval) {   
        case 's' :returnparseInt((dtEnd - dtStart) / 1000);  
        case 'n' :returnparseInt((dtEnd - dtStart) / 60000);  
        case 'h' :returnparseInt((dtEnd - dtStart) / 3600000);  
        case 'd' :returnparseInt((dtEnd - dtStart) / 86400000);  
        case 'w' :returnparseInt((dtEnd - dtStart) / (86400000 * 7));  
        case 'm' :return(dtEnd.getMonth()+1)+((dtEnd.getFullYear()-dtStart.getFullYear())*12) -(dtStart.getMonth()+1);  
        case 'y' :returndtEnd.getFullYear() - dtStart.getFullYear();  
    }  
}  
  
//+---------------------------------------------------  
//|
日期输出字符串,重载了系统的toString方法  
//+---------------------------------------------------  
Date.prototype.toString = function(showWeek)  
{   
    var myDate= this;  
    var str = myDate.toLocaleDateString();  
    if (showWeek)  
    {   
        var Week = ['
','','','','','',''];  
        str += '
星期' + Week[myDate.getDay()];  
    }  
    return str;  
}  
  
//+---------------------------------------------------  
//|
日期合法性验证  
//|
格式为:YYYY-MM-DDYYYY/MM/DD  
//+---------------------------------------------------  
function IsValidDate(DateStr)   
{   
    var sDate=DateStr.replace(/(^\s+|\s+$)/g,''); //
去两边空格;   
    if(sDate=='') return true;   
    //
如果格式满足YYYY-(/)MM-(/)DDYYYY-(/)M-(/)DDYYYY-(/)M-(/)DYYYY-(/)MM-(/)D就替换为''   
    //
数据库中,合法日期可以是:YYYY-MM/DD(2003-3/21),数据库会自动转换为YYYY-MM-DD格式   
    var s = sDate.replace(/[\d]{ 4,4 }[\-/]{ 1 }[\d]{ 1,2}[\-/]{ 1 }[\d]{ 1,2 }/g,'');   
    if (s=='') //
说明格式满足YYYY-MM-DDYYYY-M-DDYYYY-M-DYYYY-MM-D   
    {   
        var t=newDate(sDate.replace(/\-/g,'/'));   
        var ar = sDate.split(/[-/:]/);   
        if(ar[0] != t.getYear() ||ar[1] != t.getMonth()+1 || ar[2] != t.getDate())   
        {   
            //alert('
错误的日期格式!格式为:YYYY-MM-DDYYYY/MM/DD。注意闰年。');   
            returnfalse;   
        }   
    }   
    else   
    {   
        //alert('
错误的日期格式!格式为:YYYY-MM-DDYYYY/MM/DD。注意闰年。');   
        return false;   
    }   
    return true;   
}   
  
//+---------------------------------------------------  
//|
日期时间检查  
//|
格式为:YYYY-MM-DD HH:MM:SS  
//+---------------------------------------------------  
function CheckDateTime(str)  
{   
    var reg = /^(\d+)-(\d{ 1,2 })-(\d{ 1,2 }) (\d{ 1,2}):(\d{ 1,2 }):(\d{ 1,2 })$/;   
    var r = str.match(reg);   
    if(r==null)return false;   
    r[2]=r[2]-1;   
    var d= new Date(r[1],r[2],r[3],r[4],r[5],r[6]);   
    if(d.getFullYear()!=r[1])returnfalse;   
    if(d.getMonth()!=r[2])return false;   
    if(d.getDate()!=r[3])return false;   
    if(d.getHours()!=r[4])return false;   
    if(d.getMinutes()!=r[5])return false;   
    if(d.getSeconds()!=r[6])return false;   
    return true;   
}   
  
//+---------------------------------------------------  
//|
把日期分割成数组  
//+---------------------------------------------------  
Date.prototype.toArray = function()  
{   
    var myDate = this;  
    var myArray = Array();  
    myArray[0] = myDate.getFullYear();  
    myArray[1] = myDate.getMonth();  
    myArray[2] = myDate.getDate();  
    myArray[3] = myDate.getHours();  
    myArray[4] = myDate.getMinutes();  
    myArray[5] = myDate.getSeconds();  
    return myArray;  
}  
  
//+---------------------------------------------------  
//|
取得日期数据信息  
//|
参数 interval 表示数据类型  
//| y
m d w星期 ww h n s  
//+---------------------------------------------------  
Date.prototype.DatePart = function(interval)  
{   
    var myDate = this;  
    var partStr='';  
    var Week = ['
','','','','','',''];  
    switch (interval)  
    {   
        case 'y' :partStr =myDate.getFullYear();break;  
        case 'm' :partStr =myDate.getMonth()+1;break;  
        case 'd' :partStr =myDate.getDate();break;  
        case 'w' :partStr =Week[myDate.getDay()];break;  
        case 'ww' :partStr =myDate.WeekNumOfYear();break;  
        case 'h' :partStr =myDate.getHours();break;  
        case 'n' :partStr =myDate.getMinutes();break;  
        case 's' :partStr =myDate.getSeconds();break;  
    }  
    return partStr;  
}  
  
//+---------------------------------------------------  
//|
取得当前日期所在月的最大天数  
//+---------------------------------------------------  
Date.prototype.MaxDayOfDate = function()  
{   
    var myDate = this;  
    var ary = myDate.toArray();  
    var date1 = (new Date(ary[0],ary[1]+1,1));  
    var date2 = date1.dateAdd(1,'m',1);  
    var result = dateDiff(date1.Format('yyyy-MM-dd'),date2.Format('yyyy-MM-dd'));  
    return result;  
}  
  
//+---------------------------------------------------  
//|
取得当前日期所在周是一年中的第几周  
//+---------------------------------------------------  
Date.prototype.WeekNumOfYear = function()  
{   
    var myDate = this;  
    var ary = myDate.toArray();  
    var year = ary[0];  
    var month = ary[1]+1;  
    var day = ary[2];  
    document.write('< script language=VBScript\>\n');  
    document.write('myDate =Datue(''+month+'-'+day+'-'+year+'') \n');  
    document.write('result = DatePart('ww', myDate)\n');  
    document.write(' \n');  
    return result;  
}  
  
//+---------------------------------------------------  
//|
字符串转成日期类型   
//|
格式 MM/dd/YYYY MM-dd-YYYY YYYY/MM/ddYYYY-MM-dd  
//+---------------------------------------------------  
function StringToDate(DateStr)  
{   
  
    var converted = Date.parse(DateStr);  
    var myDate = new Date(converted);  
    if (isNaN(myDate))  
    {   
        //var delimCahar =DateStr.indexOf('/')!=-1?'/':'-';  
        var arys=DateStr.split('-');  
        myDate = newDate(arys[0],--arys[1],arys[2]);  
    }  
    return myDate;  
}  

 

若要显示:当前日期加时间(:2009-06-1212:00)

function CurentTime()
    { 
        var now = new Date();
       
        var year =now.getFullYear();       //

        var month = now.getMonth() +1;     //

        var day =now.getDate();            //

       
        var hh =now.getHours();            //

        var mm =now.getMinutes();          //

       
        var clock = year +"-";
       
        if(month < 10)
            clock+= "0";
       
        clock += month + "-";
       
        if(day < 10)
            clock+= "0";
           
        clock += day + " ";
       
        if(hh < 10)
            clock +="0";
           
        clock += hh + ":";
        if (mm < 10) clock +='0'; 
        clock += mm; 
        return(clock); 
    }
 

 

 

 

 

18    【File】iOS的四种方法读取文件内容

//第一种方法: NSFileManager实例方法读取数据

        NSArray*paths = NSSearchPathForDirectoriesInDomains(NSDesktopDirectory,NSUserDomainMask, YES);

        NSString*thepath = [paths lastObject];

        thepath= [thepath stringByAppendingPathComponent:@"fd_list.txt"];

        NSLog(@"桌面目录:%@", thepath);

        NSFileManager*fm = [NSFileManager defaultManager];

        NSData*data = [[NSData alloc] init];

        data= [fm contentsAtPath:thepath];

        NSLog(@"%@",[[NSStringalloc] initWithData:data encoding:NSUTF8StringEncoding]);

         

         

        //第二种方法: NSData类方法读取数据

        data= [NSData dataWithContentsOfFile:thepath];

        NSLog(@"NSData类方法读取的内容是:%@",[[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding]);

         

         

        //第三种方法: NSString类方法读取内容

        NSString*content = [NSString stringWithContentsOfFile:thepathencoding:NSUTF8StringEncoding error:nil];

        NSLog(@"NSString类方法读取的内容是:\n%@",content);

         

         

        //第四种方法: NSFileHandle实例方法读取内容

        NSFileHandle*fh = [NSFileHandle fileHandleForReadingAtPath:thepath];

        data= [fh readDataToEndOfFile];

        NSLog(@"NSFileHandle实例读取的内容是:\n%@", [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding]);

 

http://www.2cto.com/kf/201404/290149.html

 

19    【编译】Cannot define category forundefined class ‘NSString’

这个问题是由于默认没有引用Foundation.h导致

 

解决方案:

            在代码中引用#import <Foundation/Foundation.h>

 

20    【View】-[UITableViewController loadView] loaded the"XXX" nib but didn't get a UITableView.

'-[UITableViewController loadView] loaded the"XXX" nib but didn't get a UITableView.'

 

解决方法:在头文件中,将所继承的父类UITableViewController 改成 UIViewController。

 

uncaught exception 'NSInternalInconsistencyException,reason:[UITableViewController loadView] loaded the "Controller" nibbut didn't get a UITableView

http://www.tuicool.com/articles/67VN3m

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章