gpt4 book ai didi

ios - 如何在不使用 UIWebView 的情况下在 iOS 10 中显示带有 HTML 标签的文本(使用 swift)

转载 作者:行者123 更新时间:2023-11-28 19:34:52 26 4
gpt4 key购买 nike

目前我正在寻找以下问题的解决方案:

问题:我收到带有 HTML 标签的文本,例如 <b></b> , <table><tr><td></td></tr></table>等 .. 作为 JSON 响应。我需要将此数据呈现到 iOS(iphone) 应用程序的 UI 中,它应该以所需的方式表示数据,就像此数据映射到 webview 一样。即它应该使文本 <b>bold</b><table><tr><td>**draw table**</table></tr></td>根据 HTML 标签。

我正在使用 Xcode 8 和 Swift 3。

解决方案:??

最佳答案

方法总是一样的:1. 将 html 变成一个 attributedString2. 在 View/Control/TextView.. 上设置它

希望对您有所帮助。我一直在用它

import UIKit

public extension UIButton {
public func setHTMLTitle(title: NSString?, for state: UIControlState) {
guard let title = title else {
setTitle(nil, for: state)
return
}

guard let titleLabel = titleLabel else {
setTitle(nil, for: state)
return
}

if titleLabel.font == nil {
titleLabel.font = UIFont.systemFont(ofSize:UIFont.systemFontSize)
}

var c = titleColor(for: state)
if c == nil {
c = UIColor.black
setTitleColor(c, for: state)
}

setAttributedTitle(html(html: title, font: titleLabel.font, color: c!), for: state)
}
}

public extension UILabel {
public func setHTMLText(text: NSString?) {
guard let text = text else {
attributedText = nil
return
}

if font == nil {
font = UIFont.systemFont(ofSize:UIFont.systemFontSize)
}
if textColor == nil {
textColor = UIColor.black
}

attributedText = html(html: text, font: font, color: textColor)
}
}

public extension UITextView {
public func setHTMLText(text: NSString?) {
guard let text = text else {
attributedText = nil
return
}

if font == nil {
font = UIFont.systemFont(ofSize:UIFont.systemFontSize)
}
if textColor == nil {
textColor = UIColor.black
}

attributedText = html(html: text, font:font!, color:textColor!)
}
}

//shared helpers

private func html(html:NSString, font:UIFont, color:UIColor) -> NSAttributedString {
let colorName = colorToHexString(color: color)
let fontName = font.fontName
let fontSize = font.pointSize

let style = "<style>body{color: \(colorName); font-family: '\(fontName)'; font-size:\(fontSize)px;}</style>"
let htmlString = html.appending(style)
let d = htmlString.data(using: String.Encoding.utf8)!

let o = [NSDocumentTypeDocumentAttribute: NSHTMLTextDocumentType as AnyObject, NSCharacterEncodingDocumentAttribute: NSNumber(value: String.Encoding.utf8.rawValue) as AnyObject] as [String:AnyObject]

do {
let attrStr = try NSAttributedString(data:d, options:o, documentAttributes:nil)
return attrStr
}
catch {
return NSAttributedString(string: "")
}
}

private func colorToHexString(color: UIColor) -> String {
var r:CGFloat = 0
var g:CGFloat = 0
var b:CGFloat = 0
var a:CGFloat = 0

color.getRed(&r, green: &g, blue: &b, alpha: &a)

let rgb:Int = (Int)(r*255)<<16 | (Int)(g*255)<<8 | (Int)(b*255)<<0

return String(format:"#%06x", rgb)
}

***免责声明,这是我的开源库 DDUtils 的一部分

关于ios - 如何在不使用 UIWebView 的情况下在 iOS 10 中显示带有 HTML 标签的文本(使用 swift),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39999392/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com