勉強したことのメモ

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

imgタグで作成したグラフをjQueryでリアルタイムに動かす

      2014/07/03

このグラフをリアルタイムプレビューさせる。

■サンプル
http://sample.taitan916.info/graph/

■ソース
<?php
$max_a = 0;
for ($i=0; $i<5; $i++) {
$graph_val[$i] = rand(1,50);
$max_a += $graph_val[$i];
}
$max_b = max($graph_val);
?>
<!DOCTYPE HTML>
<html lang="ja">
<head>
<meta charset="UTF-8">
<style>
.graph {
min-width:300px; min-height:300px; border:solid 1px;
}
</style>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script>
$(function(){
$("[name='graph_value']").bind('keyup change', function(){ //項目をいじった際にイベント
var i = 0;
var max_a = 0;
var graph_array = new Array();
$("[name='graph_value
']").each(function() {
graph_array[i] = $("[name='graph_value']").eq(i).val();
max_a += Number(graph_array[i]); //項目の合計値
i++;
});
var max_b = Math.max.apply(null, graph_array); //項目の最大値
for(i=0; i<graph_array.length; i++){
$(".class_title1_"+i).text(graph_array[i]);
$(".class_change1_"+i).css('width',(Math.floor(graph_array[i] / max_a * 100))+'%');
$(".class_title2_"+i).text(graph_array[i]);
$(".class_change2_"+i).css('width',(Math.floor(graph_array[i] / max_b * 100))+'%');
}
});
})
</script>
<title>graph</title>
</head>
<body>
<h1>graph</h1>
<table>
<tr>
<td>
<?php
for ($i=0; $i<5; $i++) {
echo "項目" . ($i+1) . ":
<input type='text' name='graph_value
' style='width:30px' value='{$graph_val[$i]}'><br>";
}
?>
</td>
</tr>
<tr>
<td class="graph">
■本当の割合を出したもの<br>
<?php
for ($i=0; $i<5; $i++) {
echo "項目" . ($i+1) . ":<span class='class_title1_{$i}'>{$graph_val[$i]}</span><br>
<img src='./image/graph.jpg' style='height:10px; width:" . (floor($graph_val[$i] / $max_a * 100)) . "%;' class='class_change1_{$i}'><br>";
}
?>
</td>
<td class="graph">
■最大の結果を100%にして出したもの<br>
<?php
for ($i=0; $i<5; $i++) {
echo "項目" . ($i+1) . ":<span class='class_title2_{$i}'>{$graph_val[$i]}</span><br>
<img src='./image/graph.jpg' style='height:10px; width:" . (floor($graph_val[$i] / $max_b * 100)) . "%;' class='class_change2_{$i}'><br>";
}
?>
</td>
</tr>
</table>
</body>
</html>

■その他
Math.max.apply(null, graph_array)
PHPのmax関数みたいに配列の最大値を取得できる。

Number(graph_array[i])
整数値に変換。

 - jQuery, PHP

  関連記事

PHPでPOST送信する際に多次元配列も送る

PHPでPOST送信する際に多次元配列も送りたかった。ただ普通に送ろうとするとO ...

jQueryのプラグインでカラーコードを視覚的に選択

カラーコードを入力するフォームがあって、HTMLやCSSの知識がない方のために、 ...

jQueryのプラグインで簡単にイメージスライダーを作成(bxslider)

画像のスライダーを作る時に便利なプラグインであるbxslider。 簡単に使える ...

PHPでeval時のエラー

eval()'d code on line みたいなエラーが出てた。 よそのシス ...

メールサーバーを構築せずにGmailのSMPTを使ってPHPでメール送信

メールサーバーが立てられなかったり、無料サーバーのため使えなかったりといった場合 ...

PHPで配列かどうかを調べる

配列か否かを調べたいケースがあり、確認すると ばっちりそのままの関数発見。 is ...

PHPでユニークな文字列の作成

PHPでユニークな文字列を作成したかった。MySQLとかのオートインクリメントの ...

PHPで変数名を動的に変えて使う方法

変数名を動的に変えて使用したかった。 調べてみると可変変数というものがあり、希望 ...

PHPでcharset

header("Content-Type: text/html; charset ...

FullCalendarでtitle以外も表示させたい

FullCalendarでカレンダー内のイベントをクリックした際にtitle以外 ...