HTML 添加数据信息

代码如下:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8" />
        <meta name="Anthor" content="xyong" />
        <title>Title</title>
        <style>
            *{ margin:0; padding:0; font-family:"Microsoft yahei",serif;}
            li{ list-style-type: none;}
            html,body{
                height: 100%;
            }
            body{
                background: -webkit-linear-gradient(top,#8bc1de,#f9a887);
            }
            #box{
                position: relative;
                width: 1000px;
                height: 550px;
                margin: 100px auto;
            }
            #left{
                position: absolute;
                left: 0;
                top: 0;
                width: 50%;
                height: 100%;
                background: rgba(255,255,255,.8);
            }
            #right{
                position: absolute;
                right: 0;
                top: 0;
                width: 50%;
                height: 100%;
                background: rgba(0,0,0,.4);
            }
            #left .title{
                margin: 100px 0 0 50px;
                color: #f60;
            }
            #left .title span{
                color: #000;
                font-size: 14px;
                cursor: pointer;
            }
            #left .title span:hover{
                color: #ff852c;
            }
            #left ul{
                margin: 20px 0 0 50px;
            }
            #left ul li{
                float: left;
                padding: 3px 10px;
                margin: 5px;
                border: 1px solid #000;
                font-size: 14px;
            }
            #left ul li i{
                margin-right: 5px;
            }
            #left ul li span{
                cursor: pointer;
            }
            #right ul{
                margin: 100px 0 0 50px;
            }
            #right ul li{
                float: left;
                padding: 3px 10px;
                font-size: 14px;
                color: #fff;
                border: 1px solid #fff;
                margin: 5px;
            }
        </style>
    </head>
    <body>
        <div id="box">
            <div id="left">
                <div class="title">
                    热门目的地:
                    <span>马来西亚</span>
                    <span>泰国</span>
                    <span>三亚</span>
                    <span>新西兰</span>
                    <span>云南</span>
                </div>
                <ul>
                    <!--<li><i>泰国</i> | <span>×</span></li>
                    <li><i>新西兰</i> | <span>×</span></li>-->
                </ul>
            </div>
            <div id="right">
                <ul>
                    <!--<li>泰国</li>
                    <li>新西兰</li>-->
                </ul>
            </div>
        </div>
        <script>

            var aSpan = document.getElementsByClassName("title")[0].children,
                oLeftUl = document.querySelector("#left ul"),
                oRightUl = document.querySelector("#right ul"),
                length = aSpan.length;

            //给热门标签加点击事件
            for (var i = 0; i < length; i++) {
                aSpan[i].ifAdd = false;
                aSpan[i].onclick = function () {
                    if ( !this.ifAdd ){
                        this.ifAdd = true;

                        //获取点击的span的内容
                        var val = this.innerHTML;

                        //左边内容的生成
                        createLeft.call(this,val);

                        //右边内容的生成
                        createRight.call(this,val);
                    }
                };
            }

            //左边
            function createLeft(val){

                //判断是否已经生成过对应的左边节点
                if ( !this.leftLi ){
                    //先创建li,把不需要加事件的内容填充好
                    this.leftLi = document.createElement("li");
                    this.leftLi.innerHTML = "<i>"+val+"</i> | ";

                    //将需要加事件的span单独拿出来创建并赋值好事件
                    var span = document.createElement("span");
                    span.innerHTML = "×";
                    var This = this;
                    span.onclick = function () {
                        oLeftUl.removeChild(This.leftLi);
                        oRightUl.removeChild(This.rightLi);
                        //使热门标签重新可以触发点击事件
                        This.ifAdd = false; 
                    };

                    //将span 添加进 li
                    this.leftLi.appendChild(span);
                }

                //将 li 添加进 ul
                oLeftUl.appendChild(this.leftLi);
            }

            //右边
            function createRight(val){

                //判断是否生成过对应的右边节点
                if ( !this.rightLi ){
                    this.rightLi = document.createElement("li");
                    this.rightLi.innerHTML = val;
                }

                oRightUl.appendChild(this.rightLi);
            }

        </script>
    </body>
</html>


效果图如下:


知识点如下:

1、为热门标签赋予属性isAdd,从而杜绝重复添加标签的操作。

2、用标签属性存储左右新创建的li标签,当用户第二次添加热门标签时(先删除,再添加),不需要重新创建li标签。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值