UIWebView动态html到模板

Dan*_*nny 3 html iphone uiwebview ios

嗨,我想为我从xml请求中收到的数据创建一个(内部或外部)html模板.这是我的代码,到目前为止工作正常:

    NSString* desc = [screenData.jsonVars objectForKey:@"descriptionTXT"];
    NSString* title = [screenData.jsonVars objectForKey:@"titleTXT"];
    NSString* day = [screenData.jsonVars objectForKey:@"dayTXT"];
    NSString* month = [screenData.jsonVars objectForKey:@"monthTXT"];
    NSString* url = [screenData.jsonVars objectForKey:@"dataURL"];
    NSString* htmlContentString = [NSString stringWithFormat:
                                   @"<html>"
                                   "<style type=\"text/css\">"
                                   "body { background-color:transparent; font-family:Marker Felt; font-size:44;color:#fff;}"
                                   "</style>"
                                   "<body>"
                                   "<p style=\"text-align:center;font-size:65px;\">%@</p>"
                                   "<div style=\"color:#ff9900;margin:5px;padding:10px;\">%@ &nbsp;%@</div>"
                                   "<div style=\"color:#000;background:#DBDBDB;margin:5px;padding:10px;\">%@</div>"
                                   "<div style=\"color:#000;background:#ff9900;margin:5px;padding:10px;\"><a href=\"%@\">Go to website</a></div>"
                                   "</body></html>", title, day, month, desc, url];
    [BT_debugger showIt:self:[NSString stringWithFormat:@"This is the HTML: %@", htmlContentString]];
    [self.webView loadHTMLString:htmlContentString baseURL:nil];

    [self.view addSubview:webView];
Run Code Online (Sandbox Code Playgroud)

现在我想取出html并从外部或内部文件中读取.例如在template1.html中

你可以看到它是动态的(它的数据),我想保持这种方式.

任何有关此事的建议提前致谢,

D.

ton*_*har 6

目前正使用的答案+stringByReplacingOccurencesOfString:NSMutableString应该使用-replaceOccurrencesOfString:来代替.此外,NSBundle -pathForResource:返回路径,而不是文件的实际内容.这是一个有效的例子:

模板

<!-- template.html -->
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8" />
        <style type="text/css">
            body{
                font-family:"Helvetica Neue UltraLight",helvetica,verdana;
                margin-left:0;
                margin-right:0;
            }
            section{
                padding-left:5px;
                padding-right:5px;
                font-size:12px;
            }
            h1{
                font-size: 16px;
                padding-left:5px;
            }
            img{
                display: block;
                 /* 4:3 dimensions */
                width: 220px;
                height:165px;
            }
        </style>
    </head>
    <body>
       <h1>[[[name]]]</h1>
       <img src="[[[image]]]" alt="" />
       <section>
            <p>[[[full_description]]]</p>
       </section>
    </body>
</html>
Run Code Online (Sandbox Code Playgroud)

// load the template
NSString *path = [[NSBundle mainBundle] pathForResource:@"template" ofType:@"html"];
NSString *template = [NSString stringWithContentsOfFile:path encoding:NSUTF8StringEncoding error:nil];
NSMutableString *html = [NSMutableString stringWithString:template];

// make substitutions
[html replaceOccurrencesOfString:@"[[[name]]]" withString:self.building.name options:NSLiteralSearch range:NSMakeRange(0, html.length)];
[html replaceOccurrencesOfString:@"[[[image]]]" withString:self.building.image options:NSLiteralSearch range:NSMakeRange(0, html.length)];
[html replaceOccurrencesOfString:@"[[[full_description]]]" withString:self.building.fulldescription options:NSLiteralSearch range:NSMakeRange(0, html.length)];

// load html string into webView
[self.webview loadHTMLString:html baseURL:nil];
Run Code Online (Sandbox Code Playgroud)