服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Swift - 详解Swift model 解析的两种方法

详解Swift model 解析的两种方法

2021-03-29 15:30水桶前辈 Swift

这篇文章主要介绍了详解Swift model 解析的两种方法的相关资料,希望通过本文大家能够掌握这里的两种实现方法,需要的朋友可以参考下

详解Swift model 解析的两种方法

1. 常规解析方法

?
1
2
3
//懒加载声明一个LJNewsModel为数据的数组
 
lazy var ljArray : [LJNewsModel] = [LJNewsModel]()
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
//MARK:-- 数据获取和解析
extension NewsViewController{
  func requestNetData(){
    /*
     打印json数据
     */
    LJDownLoadNetImage.request("GET", url: "http://c.m.163.com/nc/article/list/T1348647909107/0-20.html") { (data, respond, error) in
       方法一:解析数据
        
       let str = String(data:data!, encoding: String.Encoding.utf8)!
       print(str)
        
       let ljTempArray : NSArray = self.getDictionaryFromJSONString(jsonString: str).object(forKey: "T1348647909107") as! NSArray
        
       for m in 0 ..< ljTempArray.count
       {
       let dict:NSDictionary = ljTempArray[m] as! NSDictionary
       let model = LJNewsModel()
       model.imageUrl = dict.object(forKey: "imgsrc") as! String
       model.contentStr = dict.object(forKey: "title") as! String
       let count :Int = (dict.object(forKey: "replyCount") != nil) ? dict.object(forKey: "replyCount") as! Int : 0
       model.replyCount = "\(count)"
       self.ljArray.add(model)
       }
       
      self.ljTablewView.reloadData()
    }
  }
   
  func getDictionaryFromJSONString(jsonString:String) ->NSDictionary{
     
    let jsonData:Data = jsonString.data(using: .utf8)!
     
    let dict = try? JSONSerialization.jsonObject(with: jsonData, options: .mutableContainers)
    if dict != nil {
      return dict as! NSDictionary
    }
    return NSDictionary()
  }
}

model

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import Foundation
 
class LJNewsModel: NSObject {
   
  //MARK:- 定义属性
  var imgsrc: String = ""  ///< store user's name, optional
  var title: String = ""   ///< store user's telephone number
  var replyCount: Int = 0
   
  //方法二的model
  override init() {
    super.init()
  }
   
  func setModel(_ imageUrl: String ,_ contentStr: String, _ replyCount:Int) {
    self.imageUrl = imageUrl
    self.contentStr = contentStr
    self.replyCount = replyCount
  }
}

2. 利用swift自有的函数进行解析-------推荐

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
//MARK:-- 数据获取和解析
extension NewsViewController{
  func requestNetData(){
    /*
     打印json数据
     */
    LJDownLoadNetImage.request("GET", url: "http://c.m.163.com/nc/article/list/T1348647909107/0-20.html") { (data, respond, error) in
       
      //as? [[String :Any]] 转化为以字典为元素的数组
      //as? [String :Any]  转化为字典
      //1.方法一:解析数据 -- 推荐
      let str = String(data:data!, encoding: String.Encoding.utf8)!
      guard let allResulrDict = self.getDictionaryFromJSONString(jsonString:str) as? [String : Any] else {return}
      guard let dataArray = allResulrDict["T1348647909107"] as? [[String :Any]] else {return}
      //print(dataArray)
       
      for dict in dataArray{
        self.ljArray.append(LJNewsModel(dict))
      }
      self.ljTablewView.reloadData()
    }
  }
   
  func getDictionaryFromJSONString(jsonString:String) ->NSDictionary{
     
    let jsonData:Data = jsonString.data(using: .utf8)!
     
    let dict = try? JSONSerialization.jsonObject(with: jsonData, options: .mutableContainers)
    if dict != nil {
      return dict as! NSDictionary
    }
    return NSDictionary()
  }
}
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import Foundation
 
class LJNewsModel: NSObject {
   
  //MARK:- 定义属性
  var imgsrc: String = ""  ///< store user's name, optional
  var title: String = ""   ///< store user's telephone number
  var replyCount: Int = 0
   
   //方法一的model
  //MARK:- 自定义构造函数
  init(_ dict : [String: Any]){
    super.init()
    setValuesForKeys(dict)
  }
 
  override func setValue(_ value: Any?, forUndefinedKey key: String) {
  }
}
<br>

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

原文链接:http://blog.csdn.net/robinson_911/article/details/77622696

延伸 · 阅读

精彩推荐