第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

Javascript版的Repeater控件實(shí)現(xiàn)

標(biāo)簽:
JavaScript

出于性能考虑项目经理规定不能用任何服务端控件(包括Repeater控件),同时尽量减少服务端处理,并尽可能压缩最终生成的html源代码,所以只用JS实现。

代码:


<html>
<head>
    <title>JavaScript的Repeater控件实现--made by 菩提树下的杨过</title>

    <script type="text/javascript">
        /*
        hashTable的javascript实现
        */
        function hashTable() {

            this.__hash = {};


            //添加key-value键值对
            this.add = function(key, value) {
                if (typeof (key) != "undefined") {
                    //if it not contains in hashtable 
                    if (!this.contains(key)) {
                        this.__hash[key] = typeof (value) == "undefined" ? null : value;
                        return true;
                    }
                    else {
                        return false;
                    }
                }
            };

            //删除key-value键值对
            this.remove = function(key) {
                delete this.__hash[key];
            };

            this.count = function() {
                var i = 0;
                for (var obj in this.__hash) {
                    i++;
                }
                return i;
            };

            //取得指定键值
            this.items = function(key) {
                return this.__hash[key];
            };


            //检查是否包含指定键
            this.contains = function(key) {
                return typeof (this.__hash[key]) != "undefined";
            };

            //清空哈希表
            this.clear = function() {
                for (var obj in this.__hash) {
                    delete this.__hash[k];
                }
            };
        }


        //替换字符串函数(strReplace中如果有正则表达式的特殊字符串,可能会出错)
        function replace(strSource, strReplace, strDestination) {
            var reg = new RegExp(strReplace, "g");
            return strSource.replace(reg, strDestination);
        }

        /*测试replace函数
        var s = "a1{0}2{0}3";
        s = replace(s,"\\{0\\}","***");
        alert(s);
        */    
    
    </script>

</head>
<body>
    <div id="Repleater1">
    </div>

    <script type="text/javascript">
      //模板替换开始
        var _sData = "1,2,3|a,b,c|x,y,z"; //实际数据字符串(服务端输出)
        var _arrData = _sData.split("|"); //数据数组
        var _template = "<div>{1}--{2}--{3}--{2}</div>"; //数据行模板
        var _fields = ['1', '2', '3']; //模板中包含的标识数组

        var _html = "";

        for (var i = 0; i < _arrData.length; i++) {
            var _htmlRows = _template; //初始行默认为行模板
            var _arrTemp = _arrData[i].split(",");
            var _hash = new hashTable();
            //将模板标识与实际数据,变成key-value键值对
            for (var j = 0; j < _fields.length; j++) {
                _hash.add(_fields[j], _arrTemp[j]);
                _htmlRows = replace(_htmlRows, "\\{" + _fields[j] + "\\}", _hash.items(_fields[j]))//根据模板标识替换为实际数据
            }

            _html += _htmlRows;
        }

        document.getElementById("Repleater1").innerHTML = _html;
    </script>
</body>
</html>
复制代码

 

欢迎转载 ,但请注明来自菩提树下的杨过 http://www.cnblogs.com/yjmyzz/archive/2009/06/19/1506849.html

點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺(jué)得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫(xiě)下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶(hù)
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專(zhuān)欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消