微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

一个容易弄错的.textContent和text()问题

最近在写一些前端页面,遇到需要通过点击事件获取被点击对象的文本内容,正确代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <script type="text/javascript" src="./js/jquery.min.js"></script>
    <Meta charset="UTF-8">
    <Meta http-equiv="X-UA-Compatible" content="IE=edge">
    <Meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Test Target</title>
</head>
<body>
    <div id="tom">
        TOmCat
        </div>
</body>

<script>
    $(document).ready(function() {
        $('#tom').click(function(e) {
            var strContent = $(e.currentTarget).text(); // 这里要用.text()获取文本内容

            alert(strContent); // output: TOmCat
        });
    });
</script>
</html>

我一顿搜索(soso),发现还有人说可以用textContent熟悉来获取,我试了一下,直接alert出来是undefined ,可见只能用.text()来获取被点击对象的文本内容
然后 .textContent属性一般用于某个具体的对象,举例如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <script type="text/javascript" src="./js/jquery.min.js"></script>
    <Meta charset="UTF-8">
    <Meta http-equiv="X-UA-Compatible" content="IE=edge">
    <Meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Test Target</title>
</head>
<body>
    <div id="tom">
        TOmCat
        <div class="tabs">
            <div class="tab-item">
                Item1
            </div>
            <div class="tab-item">
                Item2
            </div>
            <div class="tab-item">
                Item3
            </div>
        </div>
        </div>
</body>

<script>
    $(document).ready(function() {
        var objectTabItems = $('#tom .tabs div.tab-item');
        var num = objectTabItems.length;
        for(var i = 0; i < num; i++) {
            let strContent = objectTabItems[i].textContent;
                alert("this click is:" + strContent);
        }
    });
</script>
</html>

可以看出来.textContent是在取到某个具体元素对象的时候使用。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐