찾다
백엔드 개발PHP 튜토리얼急!!php页面加载不完全的问题,在线等

PHP

RT,同一个页面多次刷新,有时候正常,有时候只显示一半,有时候则完全空白
完全的页面

一半


本机调试的时候没有遇到此问题,这是在外网发布的时候发生的。下拉框中的内容是用fopen打开了一个.tab文件然后读取出来的,然后通过循环转成数组,又通过循环给js数组赋值,循环为1000。
设置了set_time_limit(60*60*10)依然无效。。。
跪求指导,谢谢。。。附上部分代码
common.php<?phppublic static function readTabFile($fileName)		{			if (!file_exists($fileName)) 			{ 				die("<b>404 File not found!</b>"); 			} 			$handle = fopen($fileName, 'rb');			$contents = fread($handle, filesize ($fileName));						//iconv("UTF-8","GBK", $contents);						if(ord($contents) == 0xEF)			{				$contents = substr($contents, 4);			}			$rows = explode("\r\n", $contents);			fclose($handle);			$ret;			$colNames = null;			for($i = 0; $i < count($rows); $i++)			{				$row = $rows[$i];				if(!empty($row) && $row != "" && substr($row, 0, 1) != "#")				{					$col = explode("\t", $row);					if(empty($colNames) || $colNames == null)						$colNames = $col;					else					{						$item;						$itemId = (int)$col[0];						if(empty($itemId))						{							die("...");						}						for($j = 0; $j < count($col); $j++)						{							$value = $col[$j];														$item[$colNames[$j]] = $value;						}						$ret[$itemId] = $item;					}				}			}			return $ret;					}?>test.php<?php    $dir = "../goods.tab";    $table = Common::readTabFile($dir);?><script>	var goodsTb = new Array();	<?php			foreach($table as $key => $value)		{			echo "goodsTb[".$value["id"]."]=\"".iconv("GBK","UTF-8", $value["sz_name"])."\";";		}	?>	function checkNum(i)	{		var sle_obj = document.getElementById('valueType' + i);		var index = sle_obj.selectedIndex;		var valueType = sle_obj.options[index].value;		var num_obj = document.getElementById('count' + i);		if(valueType == -1)		{			alert('请选择道具类型!');		}		if(num_obj.value > 500)			num_obj.value = 500;	}		var i = 1;	function addFile()	{		var dv = document.getElementById("dvFiles");		var selectObj = document.createElement("select");		selectObj.name = "valueType";		selectObj.id = "valueType" + i;				var sg = document.createTextNode("选择道具 ");		dv.appendChild(sg);		//创建select选项卡		var myOption = document.createElement("option");		myOption.setAttribute("value","-1");		myOption.appendChild(document.createTextNode("无"));		selectObj.appendChild(myOption);		for (var key in goodsTb)		{			var op = document.createElement("option");			op.setAttribute("value", key);			op.appendChild(document.createTextNode(goodsTb[key]));			selectObj.appendChild(op);		}		dv.appendChild(selectObj);....

回复讨论(解决方案)

跪求啊|!!

在线等,呜呜呜呜

管管啊

有时候正常大致可认为代码没问题
完全空白是什么意思?整个页面没一个字?
这多数是网络的问题,和代码没太大关系,除非是你的程序算法太复杂导致在浏览器超时范围内都没有响应

就是一个字都没有,空白。。。
算法也不复杂吧。。。就2个1000的循环而已,代码我也贴出来了。。。
但是肯定是跟网络有关,本地调试都是正常的。。。

空白的原因是因为js里面有个循环,执行js到一半就停止了。。。求方案

空白的原因是因为js里面有个循环,执行js到一半就停止了。。。求方案

可能是js性能问题.

强烈建议用php做循环.比如使用smarty模板,将数组传给显示模板,在里边循环 然后将循环得到的html返回或者输出前台

不要用js循环了


空白的原因是因为js里面有个循环,执行js到一半就停止了。。。求方案

可能是js性能问题.

强烈建议用php做循环.比如使用smarty模板,将数组传给显示模板,在里边循环 然后将循环得到的html返回或者输出前台

不要用js循环了
对js不是很懂- -,但是从ff页面执行源码来看,确实是前段的代码没执行完,php拿出来的数组是正确的,就是在输出js的时候停止了。
没有了解过smarty模板,请问js有解决办法吗

换了中方法,直接用php来输出js也不行。。。感觉老是输出不完全。。。

还有一种可能就是服务器的内存大小限制会有这个影响。



空白的原因是因为js里面有个循环,执行js到一半就停止了。。。求方案

可能是js性能问题.

强烈建议用php做循环.比如使用smarty模板,将数组传给显示模板,在里边循环 然后将循环得到的html返回或者输出前台

不要用js循环了
对js不是很懂- -,但是从ff页面执行源码来看,确实是前段的代码没执行完,php拿出来的数组是正确的,就是在输出js的时候停止了。
没有了解过smarty模板,请问js有解决办法吗


我觉得JS肯定有解决和优化的办法
不过我这里提不出来
我只能建议用PHP来做循环.
如果不懂smarty也没关系 就直接在php里循环 ,用echo来拼出html

为啥非得用js来循环和组合呢

echo $str;	foreach($table as $key => $value)	{		echo 'var op = document.createElement(\"option\");';		echo 'op.setAttribute(\"value\", "'.$value["id"].'");';		echo 'op.appendChild(document.createTextNode("'.iconv("GBK","UTF-8", $value["sz_name"]).'"));';		echo 'selectObj.appendChild(op)';	}	?>

用php来输出Html还是不行。。。。。。。。。。。

汗  你这个用php来输出了一堆js语句....

用PHP直接输出html不行吗.......

大概看了下你的页面最多就是几个有关联的select列表   可能还有ajax去后台取数据   php输出html+js提交查询和选择 完全可以实现    何必每一行都是js代码呢

大概看了下你的页面最多就是几个有关联的select列表   可能还有ajax去后台取数据   php输出html+js提交查询和选择 完全可以实现    何必每一行都是js代码呢
第一个下拉框就是php直接输出的html的,但是有个添加按钮,每点一次都会产生一个新的下拉框。。。。目前添加按钮用的Js实现的


大概看了下你的页面最多就是几个有关联的select列表   可能还有ajax去后台取数据   php输出html+js提交查询和选择 完全可以实现    何必每一行都是js代码呢
第一个下拉框就是php直接输出的html的,但是有个添加按钮,每点一次都会产生一个新的下拉框。。。。目前添加按钮用的Js实现的

点添加又出现一个选择道具物品的下拉框对吗?
和上一个有区别吗?
没有区别就直接将其html插入到上一个下拉单所在的div下方就可以了 

假设第一个下拉框的class=abc,下拉框和后边的输入框在同一个div下
$(".abc").parent().after($(".abc").parent().html());
jquery一句话就实现了

怎么说呢业务细节越细我这边就没法说更多了因为不了解

其实我的意思归根结底就是完全没必要使用复杂的js循环导致页面都显示不完   很多方法可以实现的

好吧,用jquery真的很简单- -
请问 $(".abc").after($(".abc").html()); 可以修改后面赋值内容的id跟name么

你是不是用了什么第三方的模板插件呐,一般引起这问题是因为模板内部缓存功能

好吧,用jquery真的很简单- -
请问 $(".abc").after($(".abc").html()); 可以修改后面赋值内容的id跟name么

当然可以  这是另一个问题

看你的这个select列表的结构和你js文件的写法了

比如你给每一项定义一个自定义属性比如说叫val="id1234"

然后当你选择某一项时  用js获取选择项的这个val和中间的text描述

然后存入后边的input的value中  (用jquery选择器会很方便)

这是js比较简单的应用了.

你是不是用了什么第三方的模板插件呐,一般引起这问题是因为模板内部缓存功能
什么插件都没用。。。


好吧,用jquery真的很简单- -
请问 $(".abc").after($(".abc").html()); 可以修改后面赋值内容的id跟name么

当然可以  这是另一个问题

看你的这个select列表的结构和你js文件的写法了

比如你给每一项定义一个自定义属性比如说叫val="id1234"

然后当你选择某一项时  用js获取选择项的这个val和中间的text描述

然后存入后边的input的value中  (用jquery选择器会很方便)

这是js比较简单的应用了.
jquery没有用过,只是参考文档能了解些语法。。。
我最早贴的图,就是我选择了物品后,需要填写数量,就是一个select跟一个text,
点击添加后,$(".abc").after($(".abc").html())这种方法,会导致select,text的id跟原来的一样,我想区分开来,比如用个变量i控制,每添加一个i就加1.。。
另外我想添加的项后面可以跟个删除按钮,点击删除可以删除本项,麻烦给个代码示例参考下,谢谢- -



好吧,用jquery真的很简单- -
请问 $(".abc").after($(".abc").html()); 可以修改后面赋值内容的id跟name么

当然可以  这是另一个问题

看你的这个select列表的结构和你js文件的写法了

比如你给每一项定义一个自定义属性比如说叫val="id1234"

然后当你选择某一项时  用js获取选择项的这个val和中间的text描述

然后存入后边的input的value中  (用jquery选择器会很方便)

这是js比较简单的应用了.
jquery没有用过,只是参考文档能了解些语法。。。
我最早贴的图,就是我选择了物品后,需要填写数量,就是一个select跟一个text,
点击添加后,$(".abc").after($(".abc").html())这种方法,会导致select,text的id跟原来的一样,我想区分开来,比如用个变量i控制,每添加一个i就加1.。。
另外我想添加的项后面可以跟个删除按钮,点击删除可以删除本项,麻烦给个代码示例参考下,谢谢- -

抱歉才到家.
写了个简单的demo,只有增加和删除DIV的  选择后写入值的可以去网上搜下相关文章

<!doctype html><html lang="cn"><head>	<meta charset="UTF-8">	<title>Document</title>	<meta name="Keywords" content="" />	<meta name="Description" content="" />	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js" type="text/javascript"></script>	<script type="text/javascript">		function addDiv(){			var lastHtml = $(".abc:last").clone();									var item_id = $(".abc:last select").attr("id");			var input_id = $(".abc:last input").attr("id");			var new_item_id = "item_" + (parseInt(item_id.substr(5))+1);			var new_input_id = "item_num_" + (parseInt(input_id.substr(9))+1);			lastHtml.children("select").attr("name",new_item_id);			lastHtml.children("select").attr("id",new_item_id);			lastHtml.children("input").attr("name",new_input_id);			lastHtml.children("input").attr("id",new_input_id);			$(".abc:last").after("<div class='abc'>"+lastHtml.html()+"</div>");		}		function delDiv(obj){			var i = $(".abc").length;			if (i>1)			{				$(obj).parent(".abc").remove();			}else{				alert("至少选择一项");			}		}	</script></head><body>	<div><!--以后换成form-->		<div class="abc">			<select name="item_1" id="item_1" >				<option value="0">无</option>				<option value="1">剑气火灵幻影</option>				<option value="2">神武至尊怒火</option>				<option value="3">鬼舞玄冰法杖</option>			</select>			数量			<input type="text" name="item_num_1" id="item_num_1" value="" />			<a href="javascript:void(0)" onclick="delDiv(this)">删除</a>		</div>		<button onClick = "addDiv()">添加</button>	</div></body></html>


欢迎继续交流啊




好吧,用jquery真的很简单- -
请问 $(".abc").after($(".abc").html()); 可以修改后面赋值内容的id跟name么

当然可以  这是另一个问题

看你的这个select列表的结构和你js文件的写法了

比如你给每一项定义一个自定义属性比如说叫val="id1234"

然后当你选择某一项时  用js获取选择项的这个val和中间的text描述

然后存入后边的input的value中  (用jquery选择器会很方便)

这是js比较简单的应用了.
jquery没有用过,只是参考文档能了解些语法。。。
我最早贴的图,就是我选择了物品后,需要填写数量,就是一个select跟一个text,
点击添加后,$(".abc").after($(".abc").html())这种方法,会导致select,text的id跟原来的一样,我想区分开来,比如用个变量i控制,每添加一个i就加1.。。
另外我想添加的项后面可以跟个删除按钮,点击删除可以删除本项,麻烦给个代码示例参考下,谢谢- -

抱歉才到家.
写了个简单的demo,只有增加和删除DIV的  选择后写入值的可以去网上搜下相关文章

<!doctype html><html lang="cn"><head>	<meta charset="UTF-8">	<title>Document</title>	<meta name="Keywords" content="" />	<meta name="Description" content="" />	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js" type="text/javascript"></script>	<script type="text/javascript">		function addDiv(){			var lastHtml = $(".abc:last").clone();									var item_id = $(".abc:last select").attr("id");			var input_id = $(".abc:last input").attr("id");			var new_item_id = "item_" + (parseInt(item_id.substr(5))+1);			var new_input_id = "item_num_" + (parseInt(input_id.substr(9))+1);			lastHtml.children("select").attr("name",new_item_id);			lastHtml.children("select").attr("id",new_item_id);			lastHtml.children("input").attr("name",new_input_id);			lastHtml.children("input").attr("id",new_input_id);			$(".abc:last").after("<div class='abc'>"+lastHtml.html()+"</div>");		}		function delDiv(obj){			var i = $(".abc").length;			if (i>1)			{				$(obj).parent(".abc").remove();			}else{				alert("至少选择一项");			}		}	</script></head><body>	<div><!--以后换成form-->		<div class="abc">			<select name="item_1" id="item_1" >				<option value="0">无</option>				<option value="1">剑气火灵幻影</option>				<option value="2">神武至尊怒火</option>				<option value="3">鬼舞玄冰法杖</option>			</select>			数量			<input type="text" name="item_num_1" id="item_num_1" value="" />			<a href="javascript:void(0)" onclick="delDiv(this)">删除</a>		</div>		<button onClick = "addDiv()">添加</button>	</div></body></html>


欢迎继续交流啊 非常感谢,结贴!
交个朋友- -

都是新手 多交流

给你个小思路 看能帮到你不!

test.php<?php    $dir = "../goods.tab";    $table = Common::readTabFile($dir);    foreach($table as $key => $value)    {      echo "<option value='{$value["id"]}'>".iconv("GBK","UTF-8", $value["sz_name"])."</option>";   	}?>test.html //加载jquery<select id="tools" name="tools[]"></select><a href="javascript:addTools();"></a><script>function autoTools(){	var i=$("#tools").length-1;$.get("test.php",function(data){$("#tools:eq("+i+")").html(data);});}function addTools(){	$("#tools").after("<select id='tools' name='tools[]'></select>").autoTools();}autoTools();</script>





好吧,用jquery真的很简单- -
请问 $(".abc").after($(".abc").html()); 可以修改后面赋值内容的id跟name么

当然可以  这是另一个问题

看你的这个select列表的结构和你js文件的写法了

比如你给每一项定义一个自定义属性比如说叫val="id1234"

然后当你选择某一项时  用js获取选择项的这个val和中间的text描述

然后存入后边的input的value中  (用jquery选择器会很方便)

这是js比较简单的应用了.
jquery没有用过,只是参考文档能了解些语法。。。
我最早贴的图,就是我选择了物品后,需要填写数量,就是一个select跟一个text,
点击添加后,$(".abc").after($(".abc").html())这种方法,会导致select,text的id跟原来的一样,我想区分开来,比如用个变量i控制,每添加一个i就加1.。。
另外我想添加的项后面可以跟个删除按钮,点击删除可以删除本项,麻烦给个代码示例参考下,谢谢- -

抱歉才到家.
写了个简单的demo,只有增加和删除DIV的  选择后写入值的可以去网上搜下相关文章

<!doctype html><html lang="cn"><head>	<meta charset="UTF-8">	<title>Document</title>	<meta name="Keywords" content="" />	<meta name="Description" content="" />	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js" type="text/javascript"></script>	<script type="text/javascript">		function addDiv(){			var lastHtml = $(".abc:last").clone();									var item_id = $(".abc:last select").attr("id");			var input_id = $(".abc:last input").attr("id");			var new_item_id = "item_" + (parseInt(item_id.substr(5))+1);			var new_input_id = "item_num_" + (parseInt(input_id.substr(9))+1);			lastHtml.children("select").attr("name",new_item_id);			lastHtml.children("select").attr("id",new_item_id);			lastHtml.children("input").attr("name",new_input_id);			lastHtml.children("input").attr("id",new_input_id);			$(".abc:last").after("<div class='abc'>"+lastHtml.html()+"</div>");		}		function delDiv(obj){			var i = $(".abc").length;			if (i>1)			{				$(obj).parent(".abc").remove();			}else{				alert("至少选择一项");			}		}	</script></head><body>	<div><!--以后换成form-->		<div class="abc">			<select name="item_1" id="item_1" >				<option value="0">无</option>				<option value="1">剑气火灵幻影</option>				<option value="2">神武至尊怒火</option>				<option value="3">鬼舞玄冰法杖</option>			</select>			数量			<input type="text" name="item_num_1" id="item_num_1" value="" />			<a href="javascript:void(0)" onclick="delDiv(this)">删除</a>		</div>		<button onClick = "addDiv()">添加</button>	</div></body></html>


欢迎继续交流啊 非常感谢,结贴!
交个朋友- - 哥们在吗?问个问题



大概看了下你的页面最多就是几个有关联的select列表   可能还有ajax去后台取数据   php输出html+js提交查询和选择 完全可以实现    何必每一行都是js代码呢
第一个下拉框就是php直接输出的html的,但是有个添加按钮,每点一次都会产生一个新的下拉框。。。。目前添加按钮用的Js实现的

点添加又出现一个选择道具物品的下拉框对吗?
和上一个有区别吗?
没有区别就直接将其html插入到上一个下拉单所在的div下方就可以了 

假设第一个下拉框的class=abc,下拉框和后边的输入框在同一个div下
$(".abc").parent().after($(".abc").parent().html());
jquery一句话就实现了

怎么说呢业务细节越细我这边就没法说更多了因为不了解

其实我的意思归根结底就是完全没必要使用复杂的js循环导致页面都显示不完   很多方法可以实现的 。。

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄)11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄)Mar 03, 2025 am 10:49 AM

종종 키워드와 추적 매개 변수로 혼란스러워하는 긴 URL은 방문자를 방해 할 수 있습니다. URL 단축 스크립트는 솔루션을 제공하여 소셜 미디어 및 기타 플랫폼에 이상적인 간결한 링크를 만듭니다. 이 스크립트는 개별 웹 사이트 a에 유용합니다

Instagram API 소개Instagram API 소개Mar 02, 2025 am 09:32 AM

Instagram은 2012 년 Facebook에서 유명한 인수에 이어 타사 사용을 위해 두 개의 API 세트를 채택했습니다. Instagram Graph API 및 Instagram Basic Display API입니다. 개발자는

Laravel의 플래시 세션 데이터로 작업합니다Laravel의 플래시 세션 데이터로 작업합니다Mar 12, 2025 pm 05:08 PM

Laravel은 직관적 인 플래시 방법을 사용하여 임시 세션 데이터 처리를 단순화합니다. 응용 프로그램에 간단한 메시지, 경고 또는 알림을 표시하는 데 적합합니다. 데이터는 기본적으로 후속 요청에만 지속됩니다. $ 요청-

Laravel Back End : Part 2, React가있는 React 앱 구축Laravel Back End : Part 2, React가있는 React 앱 구축Mar 04, 2025 am 09:33 AM

이것은 Laravel 백엔드가있는 React Application을 구축하는 데있어 시리즈의 두 번째이자 마지막 부분입니다. 이 시리즈의 첫 번째 부분에서는 기본 제품 목록 응용 프로그램을 위해 Laravel을 사용하여 편안한 API를 만들었습니다. 이 튜토리얼에서는 Dev가 될 것입니다

Laravel 테스트에서 단순화 된 HTTP 응답 조롱Laravel 테스트에서 단순화 된 HTTP 응답 조롱Mar 12, 2025 pm 05:09 PM

Laravel은 간결한 HTTP 응답 시뮬레이션 구문을 제공하여 HTTP 상호 작용 테스트를 단순화합니다. 이 접근법은 테스트 시뮬레이션을보다 직관적으로 만들면서 코드 중복성을 크게 줄입니다. 기본 구현은 다양한 응답 유형 단축키를 제공합니다. Illuminate \ support \ Facades \ http를 사용하십시오. http :: 가짜 ([ 'google.com'=> ​​'Hello World', 'github.com'=> ​​[ 'foo'=> 'bar'], 'forge.laravel.com'=>

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법Mar 14, 2025 am 11:42 AM

PHP 클라이언트 URL (CURL) 확장자는 개발자를위한 강력한 도구이며 원격 서버 및 REST API와의 원활한 상호 작용을 가능하게합니다. PHP CURL은 존경받는 다중 프로모토콜 파일 전송 라이브러리 인 Libcurl을 활용하여 효율적인 execu를 용이하게합니다.

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트Mar 13, 2025 pm 12:08 PM

고객의 가장 긴급한 문제에 실시간 인스턴트 솔루션을 제공하고 싶습니까? 라이브 채팅을 통해 고객과 실시간 대화를 나누고 문제를 즉시 해결할 수 있습니다. 그것은 당신이 당신의 관습에 더 빠른 서비스를 제공 할 수 있도록합니다.

2025 PHP 상황 조사 발표2025 PHP 상황 조사 발표Mar 03, 2025 pm 04:20 PM

2025 PHP Landscape Survey는 현재 PHP 개발 동향을 조사합니다. 개발자와 비즈니스에 대한 통찰력을 제공하는 프레임 워크 사용, 배포 방법 및 과제를 탐색합니다. 이 조사는 현대 PHP Versio의 성장을 예상합니다

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.