首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在div中未格式化的HTML生成错误

在div中未格式化的HTML生成错误
EN

Stack Overflow用户
提问于 2019-05-22 02:46:11
回答 2查看 94关注 0票数 1

我有一个cfm (ColdFusion)页面,在这里我可以在div中显示#userHTML#变量的内容。

代码语言:javascript
复制
<cfoutput>
    <div class="panel panel-default" style="margin-left: 20px; margin-right: 20px;">
        <div id="myDiv" class="panel-body">                
            #userHTML#
        </div>
    </div>

    <br/><br/>
    <div class="col-sm-8 col-sm-offset-2">
        <!-- Some Code Here -->
    </div>
</cfoutput>

有时#userHTML#变量包含无效的超文本标记语言。它可能包含未闭合的开放式<div>标记,这使得<div class="col-sm-8 col-sm-offset-2">所在的代码的其余部分位于顶层div (id="myDiv")中。

有没有一种方法可以做到这一点,这样无论#userHTML#变量包含什么内容,它都会将其内容放在"myDiv"

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-05-22 03:16:06

该浏览器被设计为在本地解析该HTML。如果您需要XML,它将应用XML规则,并且导入格式不正确的XML将会出错。如果您使用HTML,它将尽其所能自动更正错误(与所有HTML文档一样)。

要实现这一点,您可以这样做(请参阅代码中的注释):

代码语言:javascript
复制
// Create a new HTML Document (DOM)
var doc = document.implementation.createHTMLDocument ('', 'html', null);
// Add the body
var body = document.createElementNS('', 'body');
// Place the body into the DOM
doc.documentElement.appendChild(body);
// Get body parsed / corrected
body.innerHTML = "<div>This is a test";

// Now place that content into your existing DOM
document.getElementById('test').innerHTML = body.innerHTML;
// Get rid of the extra DOM
doc = null;
代码语言:javascript
复制
<div id="test">Test Div</div>

如果您检查输出的超文本标记语言,您将看到关闭的</div>已自动添加。

票数 4
EN

Stack Overflow用户

发布于 2019-05-22 21:19:00

您可以使用JSOUP来清除该超文本标记语言。从https://jsoup.orghttp://central.maven.org/maven2/org/jsoup/jsoup/获取相关的JAR文件,并将其放入lib文件夹中。

然后像这样使用JSOUP

代码语言:javascript
复制
<cfset oJSOUP = CreateObject("java", "org.jsoup.Jsoup" )>
<cfset oJSOUPWL = CreateObject("java", "org.jsoup.safety.Whitelist" ).init()>
#oJsoup.clean( 
    javaCast( "string", userHTML ), 
    "http://example.com/", 
    oJSOUPWL.relaxed().preserveRelativeLinks( true ) 
)#

这将移除不需要的HTML,如未关闭的DIVs。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56244634

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档