Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
脱・コピペプログラマー 〜Google Analytics 編〜
Search
Ryo Yoneyama
December 13, 2013
Technology
200
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
脱・コピペプログラマー 〜Google Analytics 編〜
Ryo Yoneyama
December 13, 2013
More Decks by Ryo Yoneyama
See All by Ryo Yoneyama
Web系エンジニア職とWebを支える技術の紹介
yulii
0
240
ゼロから始める IntercomでCS立ち上げ
yulii
4
1.7k
エンジニアになるきっかけとエンジニアとしてのプライド / Career Anchors (2016-08-17)
yulii
0
390
男子(おじさん)が創る女性向けサービスのデプロイ戦略
yulii
5
1.1k
テストコード文化を創る
yulii
3
990
キャリア戦略論
yulii
2
1.3k
LiBz CAREER の作り方
yulii
1
320
1 → 10 を創る開発基盤
yulii
0
8.2k
Emoji Communication
yulii
0
280
Other Decks in Technology
See All in Technology
AIソロプレナー時代に2ヶ月で20人増員した事業創造会社の開発組織の話
miyatakoji
0
570
LLMと共に進化するプロセスを目指して
ymatsuwitter
12
3.9k
Djangoユーザが知っ得なPostgreSQL機能 - 設計の選択肢を増やす / Djang-use-PostgreSQL
soudai
PRO
1
230
失敗を資産に変えるClaude Code
shinyasaita
0
300
2026TECHFRESH畢業分享會 - Lightning Talk - 打造精準高效的 MCP 設計模式與測試實務
line_developers_tw
PRO
0
730
Oracle AI Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
4
2.9k
Chainlitで作るお手軽チャットUI
ynt0485
0
180
ポケモンの型をTypeScriptの型システムで表現してみた
subroh0508
0
370
On-behalf-of Token exchange with AgentCore Identity
hironobuiga
2
140
非定型業務をAI slackbotで自動化する ~ 社内要望を自動壁打ちするbotを作った ~/automating-ad-hoc-work-with-ai-slackbot
shibayu36
0
580
作って終わりにしない タイミーのセマンティックレイヤー育成の現在地
chanyou0311
3
2.1k
チームで進めるAI駆動アジャイル×ウォーターフォール
kumaiu
0
150
Featured
See All Featured
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
11
940
Design in an AI World
tapps
1
240
Fashionably flexible responsive web design (full day workshop)
malarkey
408
66k
SEO for Brand Visibility & Recognition
aleyda
0
4.6k
A Modern Web Designer's Workflow
chriscoyier
698
190k
Music & Morning Musume
bryan
47
7.2k
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
200
SEO in 2025: How to Prepare for the Future of Search
ipullrank
3
3.5k
4 Signs Your Business is Dying
shpigford
187
22k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
The World Runs on Bad Software
bkeepers
PRO
72
12k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3.2k
Transcript
脱・コピペプログラマー ~ Google Analytics 編 ~
コピペプログラマーとは? • ググる → 見つけたコードをコピペ → OK. 動いた! Google検索から望みのコードを発掘して、コピペでソースファ イルを埋め尽くすこと(通称、スクラップブックコーディング
- 筆者命名)によって様々な難易度の高い処理を実現すること ができる。張り付けているソースを100%理解した上で使用して いる人はコピペプログラマとは呼ばない。なんとなく張り付け てなんとなく動いたというやっつけ仕事をする人を指す。 出典)プログラマのクラスチェンジ表(草稿) http://blog.mwsoft.jp/article/29852520.html
ネットに落ちてるコードを理解してますか? qsort [] = [] qsort (p:xs) = qsort lt
++ [p] ++ qsort gteq where lt = [x | x <- xs, x < p] gteq = [x | x <- xs, x >= p] このコードはなに? クイックにソート してくれる奴です。 速いっぽいッス。
<script> (function(i,s,o,g,r,a,m){ i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date(); a=s.createElement(o), m=s.getElementsByTagName(o)[0]; a.async=1; a.src=g; m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga'); ga('create', 'UA-XXXXXXX-XX', 'yulii.net'); ga('send', 'pageview'); </script> 何も考えずにコピペしてませんか?
Google Analytics は誰の担当? KPI を見える化 したいなー 経営者 GA 入れてー マーケター
アッチとコッチ(現場)の 境界線 もっと 先進的なUIに デザイナー 表と裏(黒い画面の向こう)の 境界線 エンジニア 優先順位が わかんない。。 プロデューサー 新機能追加!
JavaScript は誰が書く?? ビジネス 検討 要件定義 デザイン HTML/CSS システム開発 テスト 経営者
プロデューサー デザイナー エンジニア JavaScript JavaScript 何となく浮き球になるフロントエンド技術 ※エンジニアはもちろん、デザイナーも理解しておいたほうが良い分野 Backbone, Angular とかメリデメ考えずに入れるとサービス品質や開発効率を下げるので注意
<script> (function(i,s,o,g,r,a,m){ i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date(); a=s.createElement(o), m=s.getElementsByTagName(o)[0]; a.async=1; a.src=g; m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga'); ga('create', 'UA-XXXXXXX-XX', 'yulii.net'); ga('send', 'pageview'); </script> 本題、Let’s コードリーディング
スクリプトの読み込み処理 <script> (function(i,s,o,g,r,a,m){ i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date(); a=s.createElement(o), m=s.getElementsByTagName(o)[0]; a.async=1; a.src=g;
m.parentNode.insertBefore(a,m) })(window,document,'script','//www.google-analytics.com/analytics.js','ga'); ga('create', 'UA-XXXXXXX-XX', 'yulii.net'); ga('send', 'pageview'); </script> <script src="//www.google-analytics.com/analytics.js"></script> って書いたらダメなの?
スクリプト実行中のダウンロードブロック • src 属性で読み込むと実行完了までブロックされる JavaScript のあとに読み込み待ちのファイル (画像や別のスクリプトファイル)が出来てしまう ※近頃のモダンなブラウザーは賢いので、src 属性指定のべた書きであっても、 実は良い感じに並列化したり実行順序を考慮してくれたりします。
※async 属性が仕様上には存在するけど、非同期になるかはブラウザの実装次第みたいです。
DOM Injection による非同期ロード • script タグを動的に document に挿入する手法 • 画像などの外部ファイルを並列ダウンロードできる
• Google 先生曰く 出典)Google Analytics launches asynchronous tracking http://analytics.blogspot.jp/2009/12/google-analytics-launches-asynchronous.html ブラウザの実行順序改善によるレンダリング高速化 データの収集・精度の向上 JavaScript のロード完了前の依存性によるエラーの除去
細かい話はさて置き、とりあえず速くなる! 1章 Ajaxアプリケーションとパフォーマンス 2章応答性の高いウェブアプリケーション 3章初期ロードの分割 4章実行をブロックしないスクリプトのロード 5章非同期のスクリプトの組み合わせ 6章インラインスクリプトの適切な位置 7章効率的な JavaScriptコード
8章 Comet 9章 gzip圧縮再考 10章画像の最適化 11章主ドメインの細分化 12章ドキュメントのフラッシュ 13章 iframeの取り扱い 14章 CSSセレクタの単純化 1章 ルール1:HTTPリクエストを減らす 2章 ルール2:CDNを使う 3章 ルール3:Expiresヘッダを設定する 4章 ルール4:コンポーネントをgzipする 5章 ルール5:スタイルシートは先頭に置く 6章 ルール6:スクリプトは最後に置く 7章 ルール7:CSS expressionの使用を控える 8章 ルール8:JavaScriptとCSSは外部ファイル化する 9章 ルール9:DNSルックアップを減らす 10章 ルール10:JavaScriptを縮小化する 11章 ルール11:リダイレクトを避ける 12章 ルール12:スクリプトを重複させない 13章 ルール13:ETagの設定を変更する 14章 ルール14:Ajaxをキャッシュ可能にする 15章 米国トップ10サイトの分析 フロントエンド (HTML/CSS/JavaScript)で Web は速くなる
ベタ書き(同期) DOM Injection(非同期)
<script> (function(i,s,o,g,r,a,m){ i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date(); a=s.createElement(o), m=s.getElementsByTagName(o)[0]; a.async=1; a.src=g; m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga'); ga('create', 'UA-XXXXXXX-XX', 'yulii.net'); ga('send', 'pageview'); </script> 非同期にすると発生するアレ 読み込みが遅れたら、どうするの? そもそも、読み込みエラーしたら・・・。どうなるの?
<script> (function(i,s,o,g,r,a,m){ i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date(); a=s.createElement(o), m=s.getElementsByTagName(o)[0]; a.async=1; a.src=g; m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga'); // スクリプトが読み込まれるのを待つ処理が必要?? while (true) { if (ga) { ga('create', 'UA-XXXXXXX-XX', 'yulii.net'); ga('send', 'pageview'); break; } } </script> ベタベタな同期処理
<script> (function(i,s,o,g,r,a,m){ i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date(); a=s.createElement(o), m=s.getElementsByTagName(o)[0]; a.async=1; a.src=g; m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga'); ga('create', 'UA-XXXXXXX-XX', 'yulii.net'); ga('send', 'pageview'); </script> カッコいい同期処理 実は、同期処理がすでに考慮済み。
読み込み完了前の ga 関数
まとめ • JavaScript ロード中は、他のダウンロードがブロック – モダンブラウザは賢いので、うまく並列化されることも • 同期処理には、引数のキューを利用すると良さげ – Google
Analytics の ga.q の様に、配列に push しておく • 何気ないコードの中に使えるテクニックがあるよ – 何となくコピペしてしまったコードを読んでみよう