angular.element(document).ready(function () {
$scope.get();
});
PS. 有些於 controller 中要直接顯示 html 的情況必須在 ready 中呼叫,才能正確顯示,例如透過 AngularJS Toaster 顯示小視窗
PS. Toastr 於 angularjs 中會有 blocking 問題,必須改用 AngularJS Toaster
2017年5月18日 星期四
2017年5月15日 星期一
enter 模擬 tab 行為
.directive("entertab", function () {
return {
link: function (scope, element, attrs, ngModel) {
element.on('keydown', function (event) {
var key = event.which || event.keyCode;
if (key == 13) {
var parent = $(element).parent()[0].localName == "div" ? $(element).parent():$(element).parent().parent(); // 依階層結構自行調整寫法
for (var i = 1; i <= 30; i++) { // 避開ng-hide,最多找30次,不然就放棄
parent = $(parent).next($(parent)[0].localName);
if (parent.length==0) break;
if ($(parent).attr("class") != "ng-hide") {
var nextchild = $(parent).find('input:not(.ng-hide,:disabled, [readonly="readonly"], [disabled="disabled"]),select:not(:disabled, [readonly="readonly"], [disabled="disabled"]),button:not(:disabled, [disabled="disabled"])');
if (nextchild.length > 0) {
$(nextchild).first().focus();
event.preventDefault();
break;
}
}
}
}
});
}
}
})
return {
link: function (scope, element, attrs, ngModel) {
element.on('keydown', function (event) {
var key = event.which || event.keyCode;
if (key == 13) {
var parent = $(element).parent()[0].localName == "div" ? $(element).parent():$(element).parent().parent(); // 依階層結構自行調整寫法
for (var i = 1; i <= 30; i++) { // 避開ng-hide,最多找30次,不然就放棄
parent = $(parent).next($(parent)[0].localName);
if (parent.length==0) break;
if ($(parent).attr("class") != "ng-hide") {
var nextchild = $(parent).find('input:not(.ng-hide,:disabled, [readonly="readonly"], [disabled="disabled"]),select:not(:disabled, [readonly="readonly"], [disabled="disabled"]),button:not(:disabled, [disabled="disabled"])');
if (nextchild.length > 0) {
$(nextchild).first().focus();
event.preventDefault();
break;
}
}
}
}
});
}
}
})
2017年5月8日 星期一
ng-options 正確顯示空白字元且不要被合併
必須把空白字元轉成 String.fromCharCode(160),無法使用 或標準空白(ascii 32)
於 ng-options 中會直接顯示成
標準空白於 html 中連續出現則會自動合併
ascii 160 表示不換行空格,同時具備不會於 html 中自動被合併的特性
不換行空格 - 維基百科
javascript
====
angular.module('commonModule', []).service('commonService', function () {
var self = this;
self.replaceSpaces = function (str) {
return str.replace(/ /g, String.fromCharCode(160));
};
});
angular.module('module1', ['agGrid', 'ui.bootstrap', 'fiestah.money', 'commonModule'])
.controller('detailCtrl', function ($scope, $http, $window, $filter, $timeout, $uibModalInstance, commonService) {
$scope.commonService = commonService;
html
====
<select style="font-family:MingLiU !important" class='form-control' ng-change="selectATLINK(1)" ng-model='selectData.ATLINKObject_1' ng-options='commonService.replaceSpaces(a.text) for a in selectData.atlinks_1' ng-show='selectData.atlinks_1.length>0'>
於 ng-options 中會直接顯示成
標準空白於 html 中連續出現則會自動合併
ascii 160 表示不換行空格,同時具備不會於 html 中自動被合併的特性
不換行空格 - 維基百科
javascript
====
angular.module('commonModule', []).service('commonService', function () {
var self = this;
self.replaceSpaces = function (str) {
return str.replace(/ /g, String.fromCharCode(160));
};
});
angular.module('module1', ['agGrid', 'ui.bootstrap', 'fiestah.money', 'commonModule'])
.controller('detailCtrl', function ($scope, $http, $window, $filter, $timeout, $uibModalInstance, commonService) {
$scope.commonService = commonService;
html
====
<select style="font-family:MingLiU !important" class='form-control' ng-change="selectATLINK(1)" ng-model='selectData.ATLINKObject_1' ng-options='commonService.replaceSpaces(a.text) for a in selectData.atlinks_1' ng-show='selectData.atlinks_1.length>0'>
訂閱:
文章 (Atom)
vue3-simple-alert 學習心得
官網 顯示提示輸入訊息並於按下確定時檢查是否有輸入,防止未輸入就按確定,且和按取消用不同邏輯處理 VueSimpleAlert.fire({ title: '請輸入原因', input: 'text', showCancel...
-
1. 設定檔案下載儲存位置為 C:\Users\%username%\AppData\Local\Google\Chrome\User Data\Default\Cache 2. 勾選"下載每個檔案前詢問儲存位置" 3. 針對不要下載的檔案類型於第一...
-
自動設定欄寬 sheet.Cells.AutoFitColumns(3, 20); // 必須設定 min 跟 max 才會正常作用 凍結欄位 sheet.View.FreezePanes(4, 4); 標題列 ws.PrinterSettings.RepeatRo...
-
使用 FreeSpire.XLS ... ep.Save(); using (var workbook = new Workbook()) using (var memStream = new MemoryStream()) { workbook.LoadFromSt...