1

我有一个 HTML 字符串,想将其中的元素更改为img标签样式,宽度 = 100%,高度自动,这样当我将它们传递到 Web 视图时,图像可以适合超级视图布局。

HTML

<img alt=\"\" src=\"https://my.domain.com/img/ckeditor/55de838089041.jpg\" style=\"width:700px\" />

迅速

let doc : TFHpple = TFHpple(HTMLData: htmlText.dataUsingEncoding(NSUTF8StringEncoding))
for img: AnyObject in doc.searchWithXPathQuery("//img") {
    let imgElement : TFHppleElement = img as! TFHppleElement
    let attributes : [NSObject : AnyObject] = imgElement.attributes
    XCGLogger.defaultInstance().debug("attributes: \(attributes)")
    for eachElement : (NSObject, AnyObject) in attributes {
        if eachElement.0 == "style" {
            var elementText : String = eachElement.1 as! String
            eachElement.1 = "width:'100%',height:'auto'"
        }
     }
}

但是 eachElement.1 是不可编辑的,我可以使用 TFHpple 1做到这一点,还是必须尝试其他方式。

4

1 回答 1

1

面临一个类似的问题,我编辑了从 HMTL 响应中获得的整个字符串,所以你可以尝试这样的事情:-

    let task = try session.dataTaskWithRequest(request, completionHandler: {data, response, error -> Void in
        guard data != nil else {
            print("no data found: \(error)")
            self.displayServerAlert()
            return
        }
        print("Response: \(response)")

        var strData:String = NSString(data: data!, encoding: NSUTF8StringEncoding) as! String
        print("Body: \(strData)")

        var replaceStr = strData.stringByReplacingOccurrencesOfString("style=\"width:700px\", withString: "style=\"width:'100%',height:'auto'", options: NSStringCompareOptions.LiteralSearch, range: nil)

        print(replaceStr)
        let strtoData = replaceStr.dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: true)


        self.parseData(strtoData!)

parseData 是 fucn,我根据需要发送数据进行解析..!! 希望这可以帮助..!!

于 2016-03-19T08:08:50.330 回答