ray*_*ray 0 html internet-explorer-9 jquery-mobile
我有一个简单的HTML表单,不会在IE9中提交.它适用于Chrome,FF和IE10.
我试图在Windows 7上提交IE9,在Windows 8上提交IE10.
IE10有效,除非我将浏览器模式更改为IE9; 然后它不会提交.
演示.如果您在任何正常工作的浏览器上单击"保存",它将带您到假的demo_form.asp.
这是表格:
<!DOCTYPE html>
<html>
<head>
<title>Title</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.css" />
<script src="http://code.jquery.com/jquery-1.8.2.min.js"></script>
<script src="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.js"></script>
</head>
<body>
<div data-role="page">
<div data-role="header">
<h1>Title</h1>
</div>
<div data-role="fieldcontain">
<div class="error-messsage">
<p/>
</div>
<p>
<form action="demo_form.asp" data-ajax="false" method="get">
<input type="hidden" name="scoreType" id="_scoreType" value="T"/>
<div data-role="fieldcontain">
<fieldset class="ui-grid-a">
<div class="ui-block-a">Minutes:</div>
<div class="ui-block-b">Seconds:</div>
<div class="ui-block-a">
<input type="number" name="score_minutes" value="1" id="_scoreMinutes" maxlength="20" autocomplete="off" data-inline="true"/>
</div>
<div class="ui-block-b">
<input type="number" name="score_seconds" value="2" id="_scoreSeconds" maxlength="20" autocomplete="off" data-inline="true"/>
</div>
</fieldset>
<input type="hidden" name="score" id="_score" value="62"/>
</div>
<div data-role="fieldcontain">
<label for="_note">Note:</label>
<textarea name="note" cols="40" rows="10" id="_note" autocomplete="off"/>
</div>
<div data-role="fieldcontain">
<label for="_classAttended" class="select">Class Time:</label>
<select name="class_attended" id="_classAttended" data-native-menu="false">
<option value="-1"/>
<option value="6">06:00 am</option>>
</select>
</div>
<div data-role="fieldcontain">
<label for="_memberRating" class="select">Member Rating:</label>
<select name="member_rating" id="_memberRating" data-native-menu="false">
<option value="-1"/>
<option value="5">5 </option>
</select>
</div>
<div data-role="fieldcontain">
<label for="_rx">RX</label>
<input type="checkbox" name="rx" value="1" id="_rx" data-mini="true"/>
</div>
<div data-role="fieldcontain">
<a href="http://mysite.com/index.php/welcome/index/TRUE" data-ajax="false" data-role="button" data-inline="true">Cancel</a>
<button name="" type="Submit" id="_submit" class="ui-btn-hidden" value="Save" aria-disabled="false" data-inline="true" data-theme="b"/>
</div>
</form>
</p>
</div>
</div>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
你有一个<div>试图进入一个<form>内部的<p>.但是<div>s不能在a里面<p>,所以HTML解析器会关闭<p>元素,这样做也会关闭<form>.因此,保存按钮不在表单内,因此IE9在您单击按钮时不知道要提交的内容.删除<p>周围的标签<form>.
FF,Chrome和IE10中使用的HTML5解析器有一些很好的技巧来处理你的无效标记,但旧的IE9解析器无法应对.
此外,你有<p/>和<textarea/>.不要那样做.任何元素都不支持自闭语法.