Javascript - 删除线程

Mer*_*TİN 3 javascript

我尝试用javascript使文字删除.我对Javascript一无所知,并尝试在网上搜索如何.

 <script language="JavaScript">
            function recal(val,sum)
            { 
                if(sum == true)
                {
                    var total = parseInt(document.getElementById("total").innerHTML, 10);
                    total+=val;
                    document.getElementById("total").innerHTML=total;        
                }
                else
                {
                    var total = parseInt(document.getElementById("total").innerHTML, 10);
                    total-=val;
                    document.getElementById("total").innerHTML=total;   
                    var pnl = document.getElementById("totalEvents");
                }



                var pnl = document.getElementById("totalEvents");
                var pnl2 = document.getElementById("eventCategory");
                var pnl3 = document.getElementById("nameID");

                **strikethrough starts here**
                if (!sum && pnl.firstChild.tagName != "S" && pnl2.firstChild.tagname !="S")
                {
                    pnl.innerHTML = "<S>"+ pnl.innerHTML+"</S>";
                    pnl2.innerHTML = "<S>"+ pnl2.innerHTML+"</S>";
                }
                else 
                {
                    pnl.innerHTML = pnl.firstChild.innerHTML;
                    pnl2.innerHTML = pnl2.firstChild.innerHTML;
                }



            }
        </script>
Run Code Online (Sandbox Code Playgroud)

它使texttrikethrough,但有些事情是错误的.即使我选择第二个复选框,它影响第一个复选框为什么:(

http://jsfiddle.net/aHH9w/(我的完整html页面)

在此输入图像描述

在此输入图像描述

Roh*_*bhu 15

你正在采用一种非常复杂的方法来实现这一点,这实际上可以很容易地完成.如果您有一个HTML元素,请使用id"myelement":

<div id="myelement">Hello world</div>
Run Code Online (Sandbox Code Playgroud)

要创建一个删除线,您在JS中需要做的就是:

var ele = document.getElementById("myelement");
ele.style.setProperty("text-decoration", "line-through");
Run Code Online (Sandbox Code Playgroud)

如果您需要检查元素上是否有删除线:

var ele = document.getElementById("myelement");
var isStruck = (ele.style.getProperty("text-decoration") == "line-through");
Run Code Online (Sandbox Code Playgroud)

虽然这不是真的推荐.使用内部变量来跟踪状态.

  • 因为无论你点击什么,你只需要找到id为'totalEvents'和'eventCategory'的元素,这可能是第一行中的两个元素.您需要生成id,使它们对于每一行都是唯一的,或者实现一个逻辑来获取它们的数组.无论哪种方式,这里都涉及很多再造.我建议你先拿一本关于JavaScript的书. (2认同)