欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

自動生成文章摘要[JavaScript 版本]

 更新時間:2006年12月11日 00:00:00   投稿:mdxy-dxy  
這篇文章主要介紹了自動生成文章摘要[JavaScript 版本]

By dknt From bbs.blueidea.com

搜了搜這個,發(fā)現(xiàn)找不到答案。所以自己寫了一個,很多程序繞過這個問題,往往人工來決定在何處截斷,太麻煩了。

實現(xiàn)內(nèi)容:截斷一段含有HTML代碼的文本,但是不會出現(xiàn)圍堵標記沒有封閉的問題。

一個PHP版本的在這里?。?/span> 自動生成文章摘要[PHP版本]。

核心部分如下:

復制代碼 代碼如下:

function Generate_Brief(text,length){
    if(text.length < length) return text;
    var Foremost = text.substr(0,length);
            
    var re = /<(\/?)(BODY|SCRIPT|P|DIV|H1|H2|H3|H4|H5|H6|ADDRESS|PRE|TABLE|TR|TD|TH|INPUT|SELECT|TEXTAREA|OBJECT|A|UL|OL|LI|BASE|META|LINK|HR|BR|PARAM|IMG|AREA|INPUT|SPAN)[^>]*(>?)/ig;
    
    var Singlable = /BASE|META|LINK|HR|BR|PARAM|IMG|AREA|INPUT/i
    var Stack = new Array(), posStack = new Array();
    while(true){
        var newone = re.exec(Foremost);
        if(newone == null) break;
        
        if(newone[1] == ""){
            var Elem = newone[2];
            if(Elem.match(Singlable) && newone[3]!= ""){
                continue;
            }
            Stack.push(newone[2].toUpperCase());
            posStack.push(newone.index);
            
            if(newone[3] == "") break;
        }else{
            var StackTop = Stack[Stack.length-1];
            var End  = newone[2].toUpperCase();
            if(StackTop == End){
                Stack.pop();
                posStack.pop();
                if(newone[3] == ""){
                    Foremost = Foremost+">";
                }
            }
            
        };
    }    
    var cutpos = posStack.shift();
    Foremost = Foremost.substring(0,cutpos);
    
    return Foremost;
}


測試用例如下:

[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]

這個測試用例應該是好使,如果不行,請在純IE下打開本頁面。

主要問題是文章不能超過20000字,還差一個 HTMLencode, HTMLdecode 沒有寫進去。沒辦法只好嵌入了。

HTMLencode, HTMLdecode 在 http://cs02.100steps.net/new/onejsneeded.js 定義。不是我寫的,如果需要自己去拿吧。
我的空間速度對大家來說可能會比較慢,那我也沒辦法了...

相關(guān)文章

  • xmlHTTP返回值重編碼的優(yōu)化

    xmlHTTP返回值重編碼的優(yōu)化

    xmlHTTP返回值重編碼的優(yōu)化...
    2006-11-11
  • JS深入學習之數(shù)組對象排序操作示例

    JS深入學習之數(shù)組對象排序操作示例

    這篇文章主要介紹了JS深入學習之數(shù)組對象排序操作,結(jié)合實例形式詳細分析了JavaScript數(shù)組對象排序相關(guān)實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下
    2020-05-05
  • 微信小程序自定義導航欄(模板化)

    微信小程序自定義導航欄(模板化)

    這篇文章主要為大家詳細介紹了微信小程序自定義導航欄(模板化),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • ES2020系列之空值合并運算符 ''??''

    ES2020系列之空值合并運算符 ''??''

    這篇文章主要介紹了ES2020系列之空值合并運算符 '??',文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • 微信小程序模板之分頁滑動欄

    微信小程序模板之分頁滑動欄

    這篇文章主要為大家詳細介紹了微信小程序模板之分頁滑動欄的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • 微信小程序tabbar底部導航

    微信小程序tabbar底部導航

    這篇文章主要為大家詳細介紹了微信小程序重寫tabbar底部導航,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 淺談javascript控制HTML5的全屏操控,瀏覽器兼容的問題

    淺談javascript控制HTML5的全屏操控,瀏覽器兼容的問題

    下面小編就為大家?guī)硪黄獪\談javascript控制HTML5的全屏操控,瀏覽器兼容的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • JS隨機打亂數(shù)組的方法小結(jié)

    JS隨機打亂數(shù)組的方法小結(jié)

    這篇文章主要介紹了JS隨機打亂數(shù)組的方法,結(jié)合實例總結(jié)分析了幾種常用的數(shù)組打亂順序并重新進行排序的技巧,非常簡單實用,需要的朋友可以參考下
    2016-06-06
  • javaScript合并對象的幾個常見方式

    javaScript合并對象的幾個常見方式

    JavaScirpt中有很多對象合并的方法,今天就做個筆記,記錄一下這些方法,下面這篇文章主要介紹了javaScript合并對象的多種方式,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • 如何利用JS通過身份證號獲取當事人的生日、年齡、性別

    如何利用JS通過身份證號獲取當事人的生日、年齡、性別

    身份證可以識別一個人的信息,下面就介紹一下如何利用js通過身份證號碼獲取當事人的年齡和性別
    2016-01-01

最新評論