검색해 보니 답을 찾을 수 없었습니다. 그래서 제가 직접 작성했는데, 많은 프로그램이 이 문제를 우회하고 종종 잘라낼 부분을 수동으로 결정하는데, 이는 너무 번거로운 작업입니다.
구현 내용: HTML 코드가 포함된 텍스트를 잘라내지만 포함 태그가 닫히지 않는 문제는 없습니다.
을 자동으로 생성합니다.
핵심 부분은 다음과 같습니다.
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|주소|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( 최우선);
if(newone == null) break;
if(newone[1] == ""){
var Elem = newone[2];
if(Elem .match(Singlable) && newone[3]!= ""){
posStack.push(newone .index)
if(newone[3] == "" ) break;
var StackTop = Stack[Stack.length-1];
var End = newone[2].toUpperCase()
if(StackTop == End){
Stack.pop ();
posStack.pop();
if (newone[3] == " "){
var cutpos = posStack.shift()
Foremost = Foremost.substring (0,cutpos);
반환
}
테스트 예시는 다음과 같습니다.
외부 J를 도입해야 하는 경우 실행하려면 새로 고쳐야 합니다 ]<script>
function Do(){
var sOriginal = HtmlDecode(document.getElementById("Original").innerHTML);
var iLength = parseInt(document.getElementById("Length").value);
if(isNaN(iLength) || iLength<=0){
alert("Length Error");
}
var sBrief = Generate_Brief(sOriginal,iLength);
document.getElementById("Brief").innerHTML = htmlEncode(sBrief);
};
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;
}
</script>
이 테스트 사례는 작동해야 합니다. 그렇지 않은 경우 순수 IE에서 이 페이지를 열어보세요.
가장 큰 문제는 기사가 20,000 단어를 초과할 수 없으며 HTMLencode와 HTMLdecode가 여전히 누락되어 있다는 것입니다. 묻어둘 수밖에 없습니다.
HTMLencode, HTMLdecode는 http://cs02.100steps.net/new/onejsneeded.js에 정의되어 있습니다. 제가 쓴 게 아니니 필요하신 분은 직접 가서 받아가세요.
나의 공간 속도는 누구에게나 느려질 수 있으니 어쩔 수 없지...