4

HTML を指定した列に従って、Javascript を使用して SharePoint サイトにヘッダーを表示しています。これが HTML です。

<DIV style ='text-align:center; font-weight:bold; font-size: 20px;'>◆&lt;/DIV>

問題は、スクリプトがページ内で HTML を適切にレンダリングする一方で、ヘッダーに対して同じことを行わないことです。90% の方法で動作しますが、Unicode の "◆" を表示する代わりに、" â " をレンダリングします。

ユニコード\u25c6を考慮してJavascriptを変更しようとしましたが、惨めに失敗しています。なぜこれが起こっているのかについて、誰かが私を助けたり、手がかりを提供したりできますか?

ここにJavascriptがあります。

<script type="text/javascript">
// Find all Web Parts in the page
var listWP = [],
    calWP = [],
    divs = document.getElementById("MSO_ContentTable").getElementsByTagName("div");
var count=divs.length;
for (i=0;i<count;i++) {
    try {
        if (divs[i].id.indexOf("WebPartWPQ")==0){
            if (divs[i].innerHTML.indexOf("ViewDefault_CalendarView")>=0) {
                // Calendars
                calWP.push(divs[i].id);
            } else {
                // Other Web Parts
                listWP.push(divs[i].id);
            }
        }
    }
    catch(e){}
}
function TextToHTML(NodeSet, HTMLregexp) {
    var CellContent = "";
    var i=0;
    while (i < NodeSet.length){
        try {
            CellContent = NodeSet[i].innerText || NodeSet[i].textContent;
            if (HTMLregexp.test(CellContent)) {
                NodeSet[i].innerHTML = CellContent;
            }
        }
        catch(err){}
        i=i+1;
    }
}

var regexpA = new RegExp("\\s*<([a-zA-Z]*)(.|\\s)*/\\1?>\\s*$");
var regexpTD = new RegExp("^\\s*<([a-zA-Z]*)(.|\\s)*/\\1?>\\s*$");
var WP = new Object;

function UpdateWP() {
    if (calWP.length>0){
        for (i=0;i<calWP.length;i++) {
            WP=document.getElementById(calWP[i]);
            if (WP.innerHTML.indexOf("&lt\;")>=0) {
                TextToHTML(WP.getElementsByTagName ("a"),regexpA);
            }
        }
    }
    if (listWP.length>0){
        for (i=0;i<listWP.length;i++) {
            WP=document.getElementById(listWP[i]);
            if (WP.innerHTML.indexOf("&lt\;")>=0) {
                TextToHTML(WP.getElementsByTagName ("td"),regexpTD);
            }
        }
    }
    // Check every 200000000 ms, forever
    setTimeout("UpdateWP()",200000000);
}
UpdateWP();
function HeaderToHTML(){
    var headers=document.getElementById("MSO_ContentTable").getElementsByTagName("li");
    var regexpTR1 = new RegExp("FilterValue1=([\\S\\s]*)'\\)");
    var regexpTR2 = new RegExp("FilterValue2=([\\S\\s]*)'\\)");

    for (i=0;i<headers.length;i++) {
        try{
            var sp=headers[i].getElementsByTagName("span");
            for (j=0;j<sp.length;j++) {
                var test = sp[j].innerText || sp[j].textContent || " ";
                //var test = sp[j].innerText;
                if (test.indexOf("...")>0) {
                    //alert(test);
                    //var value = regexpTR1.exec(headers[i].innerHTML)[1];
                    var inner = headers[i].innerHTML;
                    var value = (inner.indexOf("FilterValue2")>0) ? regexpTR2.exec(headers[i].innerHTML) [1] : regexpTR1.exec(headers[i].innerHTML)[1];
                    //alert(value);
                    //alert(value.replace(/\\u00/g,"\%"));
                    value=value.replace(/\\u00/g,"%");
                    sp[j].innerHTML=unescape(unescape(value)).replace(/8_/," ");
                } 
            }
        }catch(e){}
    }
}
setInterval(function(){HeaderToHTML();},100);
</script>
4

2 に答える 2

1

解決策は、キャラクターをそのエンコーディングでレンダリングし、ブラウザに次の方法で通知することだと思います。

<meta http-equiv="Content-Type" content="text/html; charset="...">

たとえば、UTF-8を使用している場合:

<meta http-equiv="Content-Type" content="text/html; charset="UTF-8">
于 2013-01-04T18:48:45.020 に答える
1

シンボルには html dex/dec を使用することをお勧めします。
あれは、

&#x25C6;=◆
&#9670;=◆

ウィキペディアには、カテゴリごとに分類された素晴らしいリストがありますここ
あなたがここに書き込もうとしているブラック ダイヤモンドを見つけました

于 2013-01-04T18:51:51.700 に答える