Cordova 製作的 App, 取得 iframe 的 cookie 方式
var iframe = $('#iiframe')[0];
var win = iframe.contentWindow || iframe;
var doc = iframe.contentDocument || iframe.contentWindow.document;
alert(doc.cookie);
2014-09-24
使用 Cordova 打包測試 Android App (Windows 7)
記錄 Cordova 大致的使用流程:
JDK, NodeJS 和 Git client 安裝就不贅述。
2. 安裝 Android-SDK:
a. 下載解壓縮 adt-bundle (C:\Users\shinder\workspace\adt-bundle-windows-x86_64-20140702)。
b. 設定系統變數 ANDROID_SDK 為 "C:\Users\hsin-te.lin\workspace\adt-bundle-windows-x86_64-20140702\sdk"。
c. 將以下兩個路徑加入系統變數 PATH: %ANDROID_SDK%/platform-tools 和 %ANDROID_SDK%/tools。
3. 安裝 Ant build:
a. 下載解壓縮 ant (C:\Program Files\Java\apache-ant-1.9.4)。
b. 設定系統變數 ANT_HOME 為 "C:\Program Files\Java\apache-ant-1.9.4"。
c. 將 %ANT_HOME%/bin 加入系統變數 PATH。
4. 以 npm 安裝 cordova:
npm install -g cordova
5. 使用 cordova 及 android cli:
a. > cordova create hello com.example.hello HelloWorld #建立資料夾為 hello 的預設專案。
b. > cd hello #進入專案資料夾
c. > cordova platform add android #加入 android 平台
c1. 將出現錯誤, 因為 cordova 3.6 必須使用 android-19
c2. 可以先查看目前安裝的版本: android list target
c3. 使用 "SDK Manager.exe" 安裝 "android-19" 的 SDK platform 及 System Images
d. > cordova platform add android #再執行一次
e. > cordova build #建立 apk
f. > cordova build --release #建立發佈用的 apk
g. > cordova emulate android #使用 emulator 執行 apk
6. 若沒有設定模擬器 (emulator) avd:
> android list targets #先查看提供的版本
> android create avd -n and442 -t "android-19" --abi "default/x86" #建立 avd
7. 測試執行可以使用 BlueStacks App player
8. 使用 BlueStacks 必須使用簽證過的 apk (release version)
9. 使用 Java 工具建立 keystore file:
> keytool -genkey -v -keystore my_android.keystore -alias shinder -keyalg RSA -keysize 2048 -validity 10000
10. apk 簽證:
> jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore my_android.keystore .\platforms\android\ant-build\HelloWorld-release-unsigned.apk shinder
11. In BlueStacks
"/storage/sdcard/windows/BstSharedFolder" maps to "C:\ProgramData\BlueStacks\UserData\SharedFolder"
- 安裝 JDK, NodeJS, Git client (Git client 不是必要的, 不過最好裝起來)。
- 安裝 Android-SDK。
- 安裝 Ant build。
- 以 npm 安裝 cordova (global)。
- 使用 cordova cli。
JDK, NodeJS 和 Git client 安裝就不贅述。
2. 安裝 Android-SDK:
a. 下載解壓縮 adt-bundle (C:\Users\shinder\workspace\adt-bundle-windows-x86_64-20140702)。
b. 設定系統變數 ANDROID_SDK 為 "C:\Users\hsin-te.lin\workspace\adt-bundle-windows-x86_64-20140702\sdk"。
c. 將以下兩個路徑加入系統變數 PATH: %ANDROID_SDK%/platform-tools 和 %ANDROID_SDK%/tools。
3. 安裝 Ant build:
a. 下載解壓縮 ant (C:\Program Files\Java\apache-ant-1.9.4)。
b. 設定系統變數 ANT_HOME 為 "C:\Program Files\Java\apache-ant-1.9.4"。
c. 將 %ANT_HOME%/bin 加入系統變數 PATH。
4. 以 npm 安裝 cordova:
npm install -g cordova
5. 使用 cordova 及 android cli:
a. > cordova create hello com.example.hello HelloWorld #建立資料夾為 hello 的預設專案。
b. > cd hello #進入專案資料夾
c. > cordova platform add android #加入 android 平台
c1. 將出現錯誤, 因為 cordova 3.6 必須使用 android-19
c2. 可以先查看目前安裝的版本: android list target
c3. 使用 "SDK Manager.exe" 安裝 "android-19" 的 SDK platform 及 System Images
d. > cordova platform add android #再執行一次
e. > cordova build #建立 apk
f. > cordova build --release #建立發佈用的 apk
g. > cordova emulate android #使用 emulator 執行 apk
6. 若沒有設定模擬器 (emulator) avd:
> android list targets #先查看提供的版本
> android create avd -n and442 -t "android-19" --abi "default/x86" #建立 avd
7. 測試執行可以使用 BlueStacks App player
8. 使用 BlueStacks 必須使用簽證過的 apk (release version)
9. 使用 Java 工具建立 keystore file:
> keytool -genkey -v -keystore my_android.keystore -alias shinder -keyalg RSA -keysize 2048 -validity 10000
10. apk 簽證:
> jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore my_android.keystore .\platforms\android\ant-build\HelloWorld-release-unsigned.apk shinder
11. In BlueStacks
"/storage/sdcard/windows/BstSharedFolder" maps to "C:\ProgramData\BlueStacks\UserData\SharedFolder"
2014-08-30
ExtJS 5 專案開發時不使用 bootstrap.js 的方式
Sencha 建議使用 Sencha CMD 來建立 ExtJS 5 的專案, 以及進行發佈.
但在較大的專案, 許多現有的工具都比 Sencha CMD 要來得好用, 但目前以 Sencha CMD 建立的專案, 似乎只能用 Sencha CMD 發佈.
為了讓專案有良好的 MVC 架構, 在此依然使用 CMD 建立, 但會考慮以 GruntJS 做發佈。
1. 首先在解壓縮的 ext-5.0.1 目錄使用 CMD 建立專案:
2. 修改 app.js (設定套件名稱對應的路徑, 載入 Application, 設定引入的類別)
3. 修改 ext501.view.main.MainController 的 requires, 不能用 shortcut
4. 建立 index_app.html
5. 啟動 web server 拜訪 index_app.html 查看 default project 的運作。
但在較大的專案, 許多現有的工具都比 Sencha CMD 要來得好用, 但目前以 Sencha CMD 建立的專案, 似乎只能用 Sencha CMD 發佈.
為了讓專案有良好的 MVC 架構, 在此依然使用 CMD 建立, 但會考慮以 GruntJS 做發佈。
1. 首先在解壓縮的 ext-5.0.1 目錄使用 CMD 建立專案:
sencha generate app ext501 ../ext501
2. 修改 app.js (設定套件名稱對應的路徑, 載入 Application, 設定引入的類別)
Ext.Loader.setPath({
'Ext': 'ext/src',
'ext501': 'app'
});
Ext.syncRequire('Ext.app.Application');
Ext.application({
name: 'ext501',
extend: 'ext501.Application',
requires: [
"Ext.layout.container.Border",
"Ext.tab.Panel",
"ext501.view.main.MainController",
"ext501.view.main.MainModel"
],
autoCreateViewport: 'ext501.view.main.Main'
});
3. 修改 ext501.view.main.MainController 的 requires, 不能用 shortcut
requires: [
'Ext.window.MessageBox'
],
4. 建立 index_app.html
<html>
<head>
<title>ext501</title>
<link href="ext/packages/ext-theme-classic/build/resources/ext-theme-classic-all.css" rel="stylesheet" type="text/css"></link>
<script src="ext/ext-all.js" type="text/javascript"></script>
<script src="ext/packages/ext-theme-classic/build/ext-theme-classic.js" type="text/javascript"></script>
<script src="app.js" type="text/javascript"></script>
</head>
<body></body>
</html>
5. 啟動 web server 拜訪 index_app.html 查看 default project 的運作。
2014-08-08
IE8 和 Bootstrap 3
參考 IE8 issue with Twitter Bootstrap 3
shiv 讓 IE8 支援 HTML 5 標籤
respond.js 讓 IE8 支援 media query
shiv 讓 IE8 支援 HTML 5 標籤
respond.js 讓 IE8 支援 media query
<!-- HTML5 shim and Respond.js IE8 support of HTML5 elements and media queries -->
<!--[if lt IE 9]>
<script src="../../assets/js/html5shiv.js"></script>
<script src="../../assets/js/respond.min.js"></script>
<![endif]-->
另外, 最好的方式還是用 Modernizr 來判斷哪些功能沒支援, 不要直接判斷是否為 IE8.
2014-05-19
JavaScript 載入資源時的 Sync 和 Async 作法
1. 同步執行 JavaScript (Sync)
在現有的 <script> 之後加入另一個 <script> 標籤 (嚴格講起來, 不算真的 sync)
2. 非同步執行 JavaScript (Async)
在 <head> 裡加入 <script> 標籤
3. 使用 XMLHttpRequest 同步取得 JSON (Sync)
4. 使用 jQuery 同步取得 JSON (Sync)
5. 使用 XMLHttpRequest 在載入文字檔資源前, 先判斷檔案是否存在
在現有的 <script> 之後加入另一個 <script> 標籤 (嚴格講起來, 不算真的 sync)
var s = document.createElement("script");
s.type = 'text/javascript';
s.src = "js-url.js";
document.write(s.outerHTML);
2. 非同步執行 JavaScript (Async)
在 <head> 裡加入 <script> 標籤
var s = document.createElement("script");
s.type = 'text/javascript';
s.src = "js-url.js";
document.getElementsByTagName("head")[0].appendChild(s);
3. 使用 XMLHttpRequest 同步取得 JSON (Sync)
var jsonFile = 'test.json';
var req = new XMLHttpRequest();
req.open("GET", jsonFile, false); // "false": synchronous
req.send();
console.log(req.responseText);
4. 使用 jQuery 同步取得 JSON (Sync)
$.ajax({
url: appInfoUrl,
async: false, // synchronous
datatype: "json",
success: function(res){
if(typeof(res)==='string') {
res = $.parseJSON( res );
}
}
});
5. 使用 XMLHttpRequest 在載入文字檔資源前, 先判斷檔案是否存在
var jsonFile = 'test.json';
var req = new XMLHttpRequest();
req.open("GET", jsonFile, false); // "false": synchronous
req.send();
if(req.status === 404){
console.log('檔案不存在');
} else {
}
2014-04-10
Grunt.js 入門講義
● Grunt
( http://gruntjs.com/ )
名稱來自於 grunt
work (單調的工作),它的功能是使用設定來執行常做的動作,例如最小化
JavaScript
和 CSS
檔等。
● Grunt
在 0.3
版時提供常用的功能,設定檔使用
grunt.js。到
0.4
版時做了些調整,使用外掛的架構,設定檔為
Gruntfile.js。
● 本講義以 Windows
7 為作業系統為例,各軟體的安裝皆在
Windows
7 底下安裝,請注意使用的軟體版本,例如
NodeJS
有 32-bit
和 64-bit
之分。
◎ Windows
Command Prompt 使用 PowerShell
◎ 範例專案
shinder_maze.zip
和 shinder_circle_menu.zip (** blog 不提供專案包 zip 檔 )
● Web
server,使用 Python3
內建的簡易 web
server ( 非必要 )
安裝 Python
3 ( https://www.python.org/downloads/
)
在 Command
prompt,到專案目錄使用下式啟動
server
>
python -m http.server [埠號]
使用「Ctrl
+ C」停止 server
● 在安裝 Grunt
之前需先安裝 Git
和 NodeJS
◎ 1.
NodeJS ( http://nodejs.org/ )
– 直接從官網按「
INSTALL
」,下載 msi
檔並安裝。
◎ 2.
Git
– 安裝 Git
for Windows ( http://git-scm.com/download/win
)
– 安裝過程中請勾選「Run
Git from the Windows Command Prompt」
訂閱:
文章 (Atom)