Bry*_*uld 28 html javascript internet-explorer
我知道get document.getElementById和IE 存在一些问题,但不确定为什么IE出现问题.remove而所有其他浏览器都没有.任何帮助在这里将不胜感激.我收到了错误
SCRIPT438: Object doesn't support property or method 'remove'
Run Code Online (Sandbox Code Playgroud)
从错误控制台.Javascript适用于所有其他浏览器.
这是代码:
<script type="text/javascript"><!--
function removeModule() {
<?php $tab = 1; ?>
var module_row = <?php echo $module_row; ?>;
if(!confirm('Are you sure?'))
{
return false;
}
var x = 1;
while (x < module_row)
{
if (document.getElementById('tab-' + x).checked)
{
document.getElementById('tab-' + x).remove();
document.getElementById('module-' + x).remove();
document.getElementById('tab-module-' + x).remove();
}
x++;
<?php $tab++; ?>
}
$('#form').submit();
}
//--></script>
Run Code Online (Sandbox Code Playgroud)
这是来自opencart模块,它是tpl文件.我在这里也包含了部分文件,所以希望有人可以发现错误.
<?php echo $header; ?>
<div id="content">
<div class="breadcrumb">
<?php foreach ($breadcrumbs as $breadcrumb) { ?>
<?php echo $breadcrumb['separator']; ?><a href="<?php echo $breadcrumb['href']; ?>"><?php echo $breadcrumb['text']; ?></a>
<?php } ?>
</div>
<?php if ($error_warning) { ?>
<div class="warning"><?php echo $error_warning; ?></div>
<?php } ?>
<div class="box">
<div class="heading">
<h1><img src="view/image/module.png" alt="" /> <?php echo $heading_title; ?></h1>
<div class="buttons">
<a onclick="$('#form').submit();" class="button"><?php echo $button_save; ?></a>
<a onclick="removeModule();" class="button"><?php echo $button_delete ?></a>
<a onclick="location = '<?php echo $cancel; ?>';" class="button"><?php echo $button_cancel; ?></a></div>
</div>
<div class="content">
<form action="<?php echo $action; ?>" method="post" enctype="multipart/form-data" id="form">
<div class="vtabsQS">
<?php $module_row = 1; ?>
<?php foreach ($modules as $module)
{ ?>
<div style="margin-left: -7px; float:left;">
<input type="checkbox" style="float: left; margin-top: 8px;" id="tab-<?php echo $module_row; ?>" onClick="" value="#tab-<?php echo $module_row; ?>" />
<a href="#tab-module-<?php echo $module_row; ?>" id="module-<?php echo $module_row; ?>">
<?php foreach ($languages as $language)
{ ?>
<label class="inputLrgTab"><?php if (!empty($module['language_id'][$language['language_id']])) { echo $module['language_id'][$language['language_id']];} ?></label>
<?php } ?>
</a><br />
</div>
<?php $module_row++; ?>
<?php } ?>
<span id="module-add" style="clear: both; margin-left: -7px;"><?php echo $button_add_module; ?> <img src="view/image/add.png" alt="" onclick="addModule();" /></span>
</div>
<?php $module_row = 1; ?>
<?php foreach ($modules as $module) { ?>
<div id="tab-module-<?php echo $module_row; ?>" class="vtabs-content" style="margin-left:230px;">
<table class="form">
<tr>
<td><?php echo $entry_title; ?></td>
<td class="left">
<?php foreach ($languages as $language) { ?>
<img src="view/image/flags/<?php echo $language['image']; ?>" alt="<?php echo $language['name']; ?>" />
<input class="inputLrg" type="text" name="<?php echo $classname; ?>_module[<?php echo $module_row; ?>][language_id][<?php echo $language['language_id']; ?>]" value="<?php if (!empty($module['language_id'][$language['language_id']])) { echo $module['language_id'][$language['language_id']];} ?>">
<br />
<?php } ?>
<span class="error"><?php echo $error_title; ?></span>
</td>
</tr>
<tr>
<td><?php echo $entry_limit; ?></td>
Run Code Online (Sandbox Code Playgroud)
Chr*_*oph 43
remove()不幸的是,作为HTMLElements上的一种方法,Internet Explorer不支持.
你可以使用这个SO答案中的解决方法来获得一个vanilla javascript解决方案.
但是,您似乎已经使用jQuery,而是替换
document.getElementById('tab-' + x).remove();
Run Code Online (Sandbox Code Playgroud)
同
$('#tab-' + x).remove();
Run Code Online (Sandbox Code Playgroud)
Jos*_*hua 32
您应该获取要删除的元素的父元素,并使用remove子元素方法来查找和删除元素
element.parentNode.removeChild(element);
Run Code Online (Sandbox Code Playgroud)
这适用于包括IE在内的所有浏览器.
你应该用它
element.parentElement.removeChild(element);
Run Code Online (Sandbox Code Playgroud)
所有浏览器都支持,并且除了删除子元素之外,还有一些好处.
这是继续使用.remove()函数的另一种解决方法
Element.prototype.remove = function() {
this.parentElement.removeChild(this);
}
NodeList.prototype.remove = HTMLCollection.prototype.remove = function() {
for(var i = this.length - 1; i >= 0; i--) {
if(this[i] && this[i].parentElement) {
this[i].parentElement.removeChild(this[i]);
}
}
}
Run Code Online (Sandbox Code Playgroud)
然后你可以删除这样的元素
document.getElementById("my-element").remove();
Run Code Online (Sandbox Code Playgroud)
要么
document.getElementsByClassName("my-elements").remove();
Run Code Online (Sandbox Code Playgroud)
这里是Stack Overflow链接的更多信息也是这个答案的来源.
| 归档时间: |
|
| 查看次数: |
37927 次 |
| 最近记录: |