maki-o memo

制作に関する私的なメモです

選択されているタグ : js

タグを絞り込む : a-blog_cms css facebook FontAwesome Frontrend jQuery json TalkNote tips xhtml xml宣言 カスタマイズ セミナー ソーシャルボタン ツール フォームインプットメーカー ブックマークレット プラグイン 佐藤歩 勉強会 平木聡 数学 水野隼登 谷拓樹 静岡

CMSで生成したhtmlを、別サーバのhtmlでiframeを使って表示する場合、高さが算出できない件

タイトル通りの件で悩んだのでメモ。

同じサーバの場合は話が早いです。
jsでiframeで呼び出すコンテンツの高さを取ってきて、動的に書き換えればOK。

ie6以外のブラウザは、

contentWindow.document.documentElement.scrollHeight;

ie6は、

contentWindow.document.body.scrollHeight;

で、iframeの内容の高さを取って来れます。
それを、jQueryの$('iframe').height();とかで設定してやればいけます。


jQueryのプラグインを作ってみる

jQueryのプラグインを作る。
とりあえずこう書きます。

$.fn.hoge = function(引数){
    return this.each(function(){
        //ここに処理を書く
    });
}

これで例えば、hoge.jsと保存し、hoge.jsとjQuery本体を読み込みます。
そして、

$(function(){
    $('div').hoge();
});

とすれば実行できます。すげー。

ちなみに、

(function($){
    $.fn.hoge = function(){
        return this.each(function(){
            //ここに処理を書く
        });
    };
})(jQuery);

という書式もあった。どっちが正解なんだろう?


jsでの小数点第*位を四捨五入

最近調べてやっとわかったのだけれども、
どうやらJavaScriptには小数点第*位を四捨五入する関数がないらしい。

小数点以下を、切捨て・切り上げ・四捨五入 というのはある。

それを使って実装しました。

まず、対象の数値を関数で処理されたくないところまで整数にします。
具体的に言うと小数点第1位なら、その数値を10で掛けます。
その後、Mathクラスの対応する関数で処理し、
さらにその後、10で割ります。
以上で意図した数値が出せます。
以下、実行例

//小数点第1位で四捨五入したい場合
var num = 12.3456;

num = Math.round(num * 10) / 10;

これでOK。


.animateで色を制御するプラグイン『Color Animations』

jQueryの.animate()は、デフォルトでは数値型の制御しかできないらしい。 色のアニメーションをさせたかったので、探したらありました。

参考url:http://h2ham.seesaa.net/article/107837321.html

対象のjsファイルを<head>の<script>で読み込むだけで、.animate()で色の制御が可能になります。


二点間の距離

という、およそ学生時代には社会に出て使う必要なし。と判断したものを調べる機会がありました。

二点をA(x1,y1)、B(x2,y2)とし、その間の距離を求める公式。

AB = √(x2-x1)×(x2-x1)+(y2-y1)×(y2-y1)

だそうです。

ちなみにこれをjsのスクリプトでやるとこうなります。

var dx = x2-x1; var dy = y2-y1; var dxy = Math.abs(dxdx+dydy); AB = Math.round(Math.sqrt(dxy));


プロフィール

フロントエンドエンジニア

Tomokazu Makita

名古屋でフリーランスでWeb制作してます。 フロントエンドのことを主にやってます。
a-blog cmsを使用したサイト制作が得意です。
お仕事のご相談随時受付中。

雪山大すき。冬は雪山の合間に仕事します。
財布はいつも吹雪です。

エントリーリスト

タグ