勉強したことのメモ

webプログラマ見習いが勉強したことのメモ。

htmlタグが入った内容の文字を丸める

      2014/07/03

phpである文字列が○文字以上だった際、

省略してお尻に「……」をつけたいという場合、

mb_strimwidth($str,開始位置,終了位置,'丸めたあとの文字')

を最近使う。

■リファレンス

http://jp2.php.net/mb_strimwidth

ただ、今日困ったのがhtmlタグが入っている変数を

出力した際にちゃんと文字を丸めてくれない。恐らくタグの部分もカウントされているからっぽい。

で、やりたい事は、

・文字を丸めたい

・aタグやfontタグはほっといて文字列だけ丸めたい

というもの。

悩んだ結果PHPで出力したものをjQueryで読み込んで

指定文字以上なら書き換えるということで解決した。

■ソース

<?php
error_reporting(E_ALL & ~E_NOTICE);
extract($_REQUEST);
$str = '<p><font size="3" color="red"><a href="http://taitan916.hateblo.jp/" target="blank">リンクリンクリンクリンク</a></font></p>';
?>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transtional//EN" "http://www.w3c.org/TR/html4/loose.dtd">
<meta http-equiv="content-type" content="text/html"/>
<meta cherset = "UTF-8">
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script>
$(function(){
var str = $('#str').text();
alert(str);
if (str.length > 5) { //丸める対象の文字が5文字以上なら
$('#str').text(str.substring(0,5) + "…"); //丸めて後ろに…を付ける
}
});
</script>
<html lang="ja">
<head>
<title>文字を丸める</title>
</head>
<body>
<h1>文字を丸める</h1>
丸められない。途中でタグがとれて変になる。⇒<?php // echo mb_strimwidth($str,0,5,'…');?><br>
<span id="str"><?php echo $str;?></span>
</body>
</html>

 - jQuery

  関連記事

jQueryで新しく追加した要素に対してイベントがきかない場合の対応

jQueryで新たに追加した要素に対して、 clickイベントを使いたかったけど ...

PHPとSQLiteでi-mobileのデータをグラフ化

i-mobileでクリック保証のアフィリエイトだけど数値が並んでいるだけでグラフ ...

Ajaxでボタンとテキストボックス操作

ボタンを押して「https://aaa/bbb/ajax.php」からの 返答を ...

jQuery.browser~みたいなエラーが出た

jQueryのプラグインを使っていて1.9以降だと「jQuery.browser ...

jQuery2.0がリリース

リリースされたとのこと。 http://blog.jquery.com/2013 ...

lightboxで画像拡大時に文字タイトルとリンクをつける

lightboxで画像をクリックして拡大した際に、文字タイトルとその文字にリンク ...

jquery.snipeの使い方

使い方によっては面白くなりそう。 ■jquery.snipe http://ra ...

jQueryとCSSの連携

$(function(){ $("#change_small").click(f ...

スマホ対応カルーセルスライダーslickの使い方

イメージスライダーでslickという使ったことないjQueryプラグインを見かけ ...

jQselectableでセレクトボックスをリッチにする

入力フォームみたいなもので元々はテキストボックス内に 都道府県を入れてもらうとい ...