2018年1月18日 星期四

[QlikSence]安裝軟體

如何取得軟體?
請到官網https://www.qlik.com/us/try-or-buy/download-qlik-sense 註冊帳號可免費下載
Qlik Sense Desktop,安裝完成後需使用方才註冊帳號登入軟體即可使用。



檔案預設存放位置:
qvf文件位置
C:\Users\hugo\Documents\Qlik\Sense\Apps

圖片位置
C:\Users\hugo\Documents\Qlik\Sense\Content\Default

擴充物件放置位置
C:\Users\hugo\Documents\Qlik\Sense\Extensions
可至http://branch.qlik.com 下載別人開發的套件,將下載的zip解壓縮放至該目錄下即可。


2018年1月10日 星期三

[JavaScript]解決動態載入頁面驗證失效

從後端載入PartialView時,validate驗證會失效,目前解決方式是在動態載入的頁面上重新加入驗證Script
 return PartialView("_ViewSchoolPartial", viewModel);

<script type="text/javascript">
    $('#form1').validate({
        rules: {
            Name: {
                required: true,
                minlength: 2,
                maxlength: 5
            },
            JobTitle: {
                required: true,
                minlength: 2,
                maxlength: 5
            },
            Phone: {
                required: true,
                minlength: 5,
                maxlength: 20
            },
            Email: {
                required: true,
                email: true,
                minlength: 5,
                maxlength: 40
            }
        },
        messages: {
            Name: {
                required: '*必填欄位',
                minlength: '*最短字數為2個字元!',
                maxlength: '*最長字數為5個字元!'
            },
            JobTitle: {
                required: '*必填欄位',
                minlength: '*最短字數為2個字元!',
                maxlength: '*最長字數為5個字元!'
            },
            Phone: {
                required: '*必填欄位',
                minlength: '*最短字數為5個字元!',
                maxlength: '*最長字數為20個字元!'
            },
            Email: "*電子郵件格式不正確"
        },
        //以下css可換成自己的
        highlight: function (element) {
            $(element).closest('input').addClass('input-validation-error');
        },
        unhighlight: function (element) {
            $(element).closest('input').removeClass('input-validation-error');
        },
        errorElement: 'span',
        errorClass: 'field-validation-error',
        errorPlacement: function (error, element) {
            if (element.parent('input').length) {
                error.insertAfter(element.parent());
            } else {
                error.insertAfter(element);
            }
        }
    });
</script>


後來發現有個外國人寫了一個Plugin解決動態載入驗證失效的問題,上面看看就好。
 $("#divPanel").html(res);
在動態載入的下方加入以下即可
$.validator.unobtrusive.parseDynamicContent('#formID');
然後我畫面一直出現parseDynamicContent undefined,我明明頁面上都引入的js,
後來把這4隻js移到最下方終於可以了
<script src="~/Scripts/jquery.validate.min.js"></script>
 <script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>
 <script src="~/Scripts/jquery.unobtrusive-ajax.min.js"></script>
 <script src="~/Scripts/jquery.validate.unobtrusive.dynamic.js"></script>

請參考以下網站
https://xhalent.wordpress.com/2011/01/24/applying-unobtrusive-validation-to-dynamic-content/

最新解決方案 20190430
$("#divPanel").html(res);
//動態載入後請使用下列方式
$.validator.unobtrusive.parse("#form2");
使用jQuery Validation Plugin v1.17.0






2018年1月2日 星期二

[MVC]DropDownListFor指定值

今天遇到了一個以前都沒注意過的問題,搞了好久才搞定。
就是我在Action裡Return PartialView並傳回model,
頁面上放了@Html.DropDownListFor(m => m.RelationshipType, (SelectList)ViewData["RelationshipTypeName"], "==請選擇=="),就是吃不到傳回的值,
後來發現是因為ViewData["RelationshipType"]的名稱與m => m.RelationshipType 一樣就不行,
改成不一樣就行了,詳細原因晚點在研究,或有高人可以指點一下。


2017年12月19日 星期二

[MVC]section Scripts -is not a function

今天遇到一個問題就是頁面上一直出現is not a function。
已確認頁面上都有載入js,以前用vs2012都沒出現過這個問題,目前是用vs2015
後來發現在view上引用js必須使用section Scripts包起來才會正確顯示。
如果沒有用section Scripts包起來的話js出現的位置會在比較上面,因該是載入順序的問題。

@section Scripts {
    <script src="~/Content/js/xxx.js"></script>
}

2017年11月30日 星期四

[C#]手機設定以電腦解析度瀏覽

因目前系統雖然有做rwd設計,但有時介面未針對手機裝置特別設計UI,導致以手機瀏覽內容過多時會縮擠在一起,目前暫時以手機瀏覽時以電腦解析度瀏覽。


@using System.Text.RegularExpressions;
 string u = Request.ServerVariables["HTTP_USER_AGENT"];
    Regex b = new Regex(@"(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino", RegexOptions.IgnoreCase | RegexOptions.Multiline);
    Regex v = new Regex(@"1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-", RegexOptions.IgnoreCase | RegexOptions.Multiline);

bool mobile = false;
if ((b.IsMatch(u) || v.IsMatch(u.Substring(0, 4))))
 {
        mobile = true;
  }

//如果是手機以1280解析度瀏覽
@if (mobile == true)
    {
        <meta name="viewport" content="width=1280, initial-scale=1, user-scalable=yes" />
    }


好東西,判斷是否為手機裝置,有提供各種語言版本
http://detectmobilebrowsers.com/

2017年11月10日 星期五

[C#]Transaction 避免重複交易

筆記一下

TransactionOptions options = new TransactionOptions();
options.IsolationLevel = System.Transactions.IsolationLevel.ReadCommitted;
options.Timeout = new TimeSpan(0, 1, 0);
using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required, options))
{
  //交易開始

........



   scope.Complete();
}



Visual Studio JS intellisense 失效解決方式

  試了好久,發現到工具>選項>IntelliCode js項目設定啟用,重新開啟VS就正常了! 後來發現是TypeScript3.2版有問題停用,使用4.3版的TypeScript即可