2

現在、jQuery Grid を使用してスペイン語で記述されたデータを表示しています。データはアクセント ( ´ ) で完全に表示されますが、アクセントを使用してデータを検索しようとすると、サーバーはアクセント付きの文字ではなく ∫√ のような不正な文字列を取得します。

また、同じページでフォームを送信するアクセント付きのデータを送信できるため、これは jQuery Grid の問題であると確信しています。

また、次のようにヘッダーにコンテンツ タイプを追加しました。

<%@ page contentType="text/html;charset=UTF-8" %>
<sj:head jquerytheme="redmond" locale="es" />

これは、struts2 プラグインで使用している jQuery グリッドのコードです。

<s:url id="remoteurl" action="tabla-historial-director"  />
<s:url id="selectperiodourl" action="periodos" />

<sjg:grid
    id="grid"
    caption="Trabajos Terminales dirigidos"
    dataType="json"
    href="%{remoteurl}"
    pager="true"
    navigator="true"
    navigatorAdd="false"
    navigatorDelete="false"
    navigatorEdit="false"  
    gridModel="gridModel"
    rowList="3,10,15,20"
    rowNum="10"
    hidegrid="false"
    gridview="true"
    viewrecords="true"
>
    <sjg:gridColumn 
    align="center"  
        name="numRegistro"
        index="numRegistro"
        title="No. de registro"
        width="120"
        sortable="true"
        search="true"
        searchoptions="{sopt:['eq']}"
    />
    <sjg:gridColumn
        name="titulo"
        index="titulo"
        title="Título"
        width="840"
        search="true"
        searchoptions="{sopt:['cn']}"
    />
    <sjg:gridColumn
        align="center"
        name="tipo"
        index="tipo"
        title="Tipo"
        width="60"
        search="false"
    />
    <sjg:gridColumn
        align="center"
        name="periodo"
        index="periodo"
        title="Periodo"
        width="80"
        search="true"
        surl="%{selectcountrysurl}"
        searchoptions="{sopt:['eq'], dataUrl : '%{selectperiodourl}'}"
        searchtype="select"
    />
    <sjg:gridColumn
        align="center"
        index="objetivo"
        name="objetivo"
        editable="true"
        sortable="true"
        hidden="true"
        editrules="{ edithidden : true } "
        title="Objetivo"
        width="20"
    />
    <sjg:gridColumn 
        search="false"
        sortable="false"
        name="idTT"
        key="true" 
        title="Acción"
        width="80"
        formatter="formatLink"
    />
</sjg:grid>

検索ボタンとスペイン語のアクセントの使い方を教えてください。どうもありがとうございました。

4

1 に答える 1

0

誰かがここで同様の問題を解決した可能性があります: JQuery punctuation for spanish (ó, í, etc) not working in IE8.

彼は次のことを行いました。

header("text/html; charset=iso-8859-1");

この回答には、さらにいくつかの手がかりがあります: jQuery AJAX Character Encoding

男が言ったこと: 「UTF-8 は、すべてのアクセントと外国語の文字を処理することになっています。データ ソースで使用しないのはなぜですか?

そもそもすべてを UTF-8 にする必要があります。ファイルをメモ帳++にロードし、utf-8に変換し、文字をアクセントに手動で変更する必要がありました。完了すると、すべてが魔法のように機能します。

ところで、サーバーが.htmlファイルをphp処理するように定義されていない限り、ajaxでロードしているファイルはiso文字セットを取得していません。iso charset の使用を主張する場合は、html ファイルではなく php ファイルを要求し、(ファイル自体ではなく) ヘッダーで charset を定義します。"

これはあなたを助けていますか?

HTML に適したコードをいつでも試して、検索に置き換えることができます: http://webdesign.about.com/od/localization/l/blhtmlcodes-sp.htm

別の男がここでスペイン語の文字の問題に遭遇しました: http://ianloic.com/2009/12/27/jquery-selector-escaping/

彼はエスケープ関数を書きましたが、それはあなたが求めていたものではないかもしれません:

(function($) {
if ($) {
var escape_re = /[#;&,\.\+\*~':"!\^\$\[\]\(\)=>|\/\\]/,
escapeCharacters = {
‘#’: 1,
‘;’: 1,
‘&amp;’: 1,
‘,’: 1,
‘.’: 1,
‘+’: 1,
‘*’: 1,
‘~’: 1,
‘\”: 1,
‘:’: 1,
‘”‘: 1,
‘!’: 1,
‘^’: 1,
‘$’: 1,
‘[': 1,
']‘: 1,
‘(‘: 1,
‘)’: 1,
‘=’: 1,
‘&gt;’: 1,
‘|’: 1,
‘/’: 1,
‘\\’: 1
};
$.escape = function(s){
var ret = ”, offset;
if (s && ((offset = s.search(escape_re)) !== -1)) { // look for an occurence of a special character
ret = s.substr(0, offset) + ‘\\’ + s[offset];
for(var i=offset + 1, len=s.length, ch; i < len; i++){ // assume that another special character may occur so we just loop through the rest of the string
ch = s[i];
ret += (escapeCharacters[ch]? '\\': '') + ch;
}
}
return ret;
};
}
})(window.jQuery);

h番目

于 2012-08-28T02:21:48.670 に答える