从不同的id获取内部HTML
Getting inner HTML from different ids
我刚刚开始尝试学习Javascript,所以请耐心等待。我正试图通过点击按钮将信息从页面一部分的列表中获取到一个新的部分,该部分有三个位置。
列表中的每个项目都有自己的按钮,我需要我的脚本根据按钮的点击次数(应该与已经添加到列表中的列表项目数量一致)来知道将列表项目放在哪个位置。
我试着创建了一个脚本来增加I,并将段落的id放入一个函数中,但我似乎无法使其工作。我希望通过"计数"按钮的点击次数,它会将添加的每个新列表项放在新部分的下一个位置。
不过,我不知道如何使计数部分工作,我刚刚想到,也许我函数的第一部分一直保持在零。
我真的很感激能在这方面得到任何帮助。
提前感谢!
这是我的代码:
<script>
function increase(place) {
var i = 0;
addToDilly(i, place);
i++;
}
function addToDilly(num, place) {
if num = 0 {
document.getElementById("firstStop").innerHTML = document.getElementById(place).innerHTML;
}
if num = 1 {
document.getElementById("secondStop").innerHTML = document.getElementById(place).innerHTML;
}
if num = 2 {
document.getElementById("thirdStop").innerHTML = document.getElementById(place).innerHTML;
}
}
</script>
<p id="firstStop">This is a paragraph.</p>
<p id="secondStop">This is another paragraph.</p>
<p id="thirdStop">This is another paragraph.</p>
<hr/>
<p id="1">Royal Oak <button onclick="increase(1)">Add To Dilly</button></p>
<p id="2">Ferndale <button onclick="increase(2)">Add To Dilly</button></p>
<p id="3">Chesterfield <button onclick="increase(3)">Add To Dilly</button></p>
试试这个脚本:
<script>
var i = 0;
function increase(place) {
console.log(place);
addToDilly(i, place);
i++;
}
function addToDilly(num, place) {
if (num == 0) {
document.getElementById("firstStop").innerHTML = document.getElementById(place).innerHTML;
}
if (num == 1) {
document.getElementById("secondStop").innerHTML = document.getElementById(place).innerHTML;
}
if (num == 2) {
document.getElementById("thirdStop").innerHTML = document.getElementById(place).innerHTML;
}
}
</script>
下面是的运行示例
我建议彻底重写。如果你的目标是更新项目列表,只需更新项目列表(字面意思):)
注意:您最初将问题标记为jQuery,因此这个初始答案在jQuery中
要添加的文本需要位于与按钮相关的元素中,但不包含按钮本身。在这个例子中,我把它们放在按钮之前。
例如。http://jsfiddle.net/TrueBlueAussie/t13h54bu/3/
$('button').click(function () {
var $button = $(this);
var text = $button.prev('p').html();
var $target = $('#list');
$target.append($('<li>').html(text));
});
和更简单的HTML:
<ul id="list"></ul>
<hr/>
<p>Royal Oak</p>
<button>Add To Dilly</button>
<p>Ferndale</p>
<button>Add To Dilly</button>
<p>Chesterfield</p>
<button>Add To Dilly</button>
然后,如果你想将项目限制为3个,请添加以下内容:
if ($target.children().length < 3) {
$target.append($('<li>').html(text));
}
http://jsfiddle.net/TrueBlueAussie/t13h54bu/4/
相关文章:
- 能够获取元素长度,但不能获取内部 HTML
- 如何使用JS抓取页面以获取内部链接?它也必须递归地完成
- 如何获取内部动态加载图像的元素的高度
- 使用javascript获取内部HTML元素
- 如何在普通 JavaScript 中获取内部子节点的最外层父节点
- 获取内部范围的文本
- 使用 JavaScript 获取内部 HTML 文本时出现问题
- 获取内部 HTML 如已更改
- 如何根据属性 ID 获取内部 html
- 获取内部文本并将其拆分.使用innerHTML和split的Javascript问题
- 使用 JavaScript 从 XML 文件中获取内部元素
- 从动态添加的脚本标记中获取内部 HTML
- 使用 jQuery 从 Chrome 中的 XML 节点获取内部 XML
- 如何使用jquery2.0获取内部HTML
- 获取内部输入<tr>在tbody中标记
- 从类中获取内部 HTML
- 在laravel 5.1上使用此代码获取内部服务器错误500
- 为jsp中的每个循环获取内部隐藏字段的值
- 从不同的id获取内部HTML
- Drupal:Ajaxpost获取内部服务器错误