ホームページ  >  記事  >  バックエンド開発  >  中国語と英語の utf8 での統一されたカウントおよび傍受方法を探しています。

中国語と英語の utf8 での統一されたカウントおよび傍受方法を探しています。

WBOY
WBOYオリジナル
2016-06-13 12:15:571236ブラウズ

中国語、英語 utf8 での統一カウントとインターセプト方法を探しています。
Web ページを作成するときに、1 行に 37 文字しかない場合は、それをすべて表示する必要があります。それは、17 文字の中国語文字または 34 文字に切り取られます。英語の文字長に省略記号として 3 つのドット「...」を加えたものです。ユーザーがどの国を使用しているか (おそらくロシア語も) 判断できないため、統一されたアルゴリズムが必要です。私に解決策があることを誰が知っているかわかりません、ありがとう。
------解決策のアイデア----------------------
インターセプト関数の比較があります。 ThinkPHP フレームワーク 悪くない

/**<br /> +----------------------------------------------------------<br /> * 字符串截取,支持中文和其他编码<br /> +----------------------------------------------------------<br /> * @static<br /> * @access public<br /> +----------------------------------------------------------<br /> * @param string $str 需要转换的字符串<br /> * @param string $start 开始位置<br /> * @param string $length 截取长度<br /> * @param string $charset 编码格式<br /> * @param string $suffix 截断显示字符<br /> +----------------------------------------------------------<br /> * @return string<br /> +----------------------------------------------------------<br /> */<br />function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true)<br />{<br />    if(function_exists("mb_substr"))<br />	{<br />		if ($suffix && strlen($str)>$length)<br />			return mb_substr($str, $start, $length, $charset)."...";<br />        else<br />			return mb_substr($str, $start, $length, $charset);<br />    }<br />    elseif(function_exists('iconv_substr'))<br />	{<br />		if ($suffix && strlen($str)>$length)<br />			return iconv_substr($str,$start,$length,$charset)."...";<br />        else<br />			return iconv_substr($str,$start,$length,$charset);<br />    }<br /><br />    $re['utf-8']   = "/[\x01-\x7f]<br><font color='#FF8000'>------解决思路----------------------</font><br>[\xc2-\xdf][\x80-\xbf]<br><font color='#FF8000'>------解决思路----------------------</font><br>[\xe0-\xef][\x80-\xbf]{2}<br><font color='#FF8000'>------解决思路----------------------</font><br>[\xf0-\xff][\x80-\xbf]{3}/";<br />    $re['gb2312'] = "/[\x01-\x7f]<br><font color='#FF8000'>------解决思路----------------------</font><br>[\xb0-\xf7][\xa0-\xfe]/";<br />    $re['gbk']    = "/[\x01-\x7f]<br><font color='#FF8000'>------解决思路----------------------</font><br>[\x81-\xfe][\x40-\xfe]/";<br />    $re['big5']   = "/[\x01-\x7f]<br><font color='#FF8000'>------解决思路----------------------</font><br>[\x81-\xfe]([\x40-\x7e]<br><font color='#FF8000'>------解决思路----------------------</font><br>\xa1-\xfe])/";<br />    preg_match_all($re[$charset], $str, $match);<br />    $slice = join("",array_slice($match[0], $start, $length));<br />    if($suffix)<br />		return $slice."…";<br />    return $slice;<br />}

-----ソリューションのアイデア----------------------
ブラウザでは、1 つの中国語文字が 2 つの欧文文字の位置を占めます。
この前提の下では、utf-8 でエンコードされた中国語と欧文が混在した表示幅になります。文字列 (スペイン語は 1、中国語は 2) 以下の計算式があります
(バイト単位の長さ - 単語単位の長さ) / 2 単語単位の長さ

たとえば、aa China
を押します。バイト単位は 8
ワード単位の長さは 4
(8-4)/2 4 = 6
つまり、6 表示単位

必要に応じて最初に表示を指定します長さがある場合は、ループ テストを行う必要があります


実際、CSS はより良い解決策を提供しています
<style><br />body{<br />  background-color:#f4f4f4;<br />  font-size:12px;<br />}<br />div.test{<br />  width:200px;<br />  height:60px;<br />  border:1px solid red;<br />  border-top:4px solid red;<br />  padding:10px;<br />  overflow:hidden;<br />  text-overflow:ellipsis;<br />  white-space:nowrap;<br />}<br /></style><br /><div class="test">DIV+CSS模板、后台模板、图片图标下载,CSS代码实例、CSS导航菜单、CSS图表<br /></div><br />

-----解決策のアイデア -- ----------
text-overflow:ellipsis; IE のみのようです。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。