顯示具有 Ajax 標籤的文章。 顯示所有文章
顯示具有 Ajax 標籤的文章。 顯示所有文章

2013年4月9日 星期二

Good WEB UI Framework - Vaadin

好久沒有看到讓人興奮的新技術了,趁睡不著的時候,趕快紀錄一下~

今天同事分享了 Vaadin 這個Framework,真的讓我有驚為天人的感覺。其實他的概念和之前接觸到的JSF很像,不過看了原廠和同事的Demo後覺得這個真的是不錯的Framework,開發上使用了之前Java上慣用的Swing開發方式,前台網頁和JavaScript 和 AJAX 的互動全部由後台程式產生, 對開發人員而言真的是很方便。想到之前和CSS還有JQuery 奮戰的過程,不禁讓人覺得相見恨晚阿。不過看起來這樣的架構會不會有讓美工人員不易和程式設計師分工的問題還要深入研究一下, 當然對於中小型專案影響不大。

然後重要的來了~他是採Apache V2 授權的開放原始碼專案,可以有效降低期初的投入成本,商業應用上也比較ok。

其他的部份要看完文件和實做才能深入體驗,看起來文件也蠻豐富的,又有新東西可以研究了,也是美事一樁阿~

https://vaadin.com/comparison 這個比較表很適合快速瀏覽一下他和其他framework的不同。



2011年6月30日 星期四

Play Framework 實驗筆記 4- 使用jqGrid 作資料維護

這一部分是將前端表格顯示的部份作改善。
使用的元件是jqGrid。這是jqGrid的Demo,裡面有許多使用範例,有興趣的可以去看一下,這邊只會用到以下這些簡單的功能。

1. 使用AJAX 的方式,向Server取得 JSON 格式的資料
2. 支援常見的分頁方式
3. 編輯時使用 inline editor 的方式

檔案位置:

檔案要放對位置
*.css 放在 N:\PlayFramework\play-1.1\members\public\stylesheets
css中用到的圖檔放在 N:\PlayFramework\play-1.1\members\public\stylesheets\images


*.js 放在 N:\PlayFramework\play-1.1\members\public\javascripts

View
View 的部份要將相關的js 檔include進來。我決定直接加在main.html
N:\PlayFramework\play-1.1\members\app\views\main.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">

    <head>
        <title>#{get 'title' /}</title>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
        <link rel="stylesheet" type="text/css" media="screen" href="@{'/public/stylesheets/main.css'}">
  <link rel="stylesheet" type="text/css" media="screen" href="@{'/public/stylesheets/jquery-ui-1.8.12.custom.css'}">
  <link rel="stylesheet" type="text/css" media="screen" href="@{'/public/stylesheets/ui.jqgrid.css'}">
  
        #{get 'moreStyles' /}
        <link rel="shortcut icon" type="image/png" href="@{'/public/images/favicon.png'}">
        <script src="@{'/public/javascripts/jquery-1.4.2.min.js'}" type="text/javascript" charset="utf-8"></script>
        <script src="@{'/public/javascripts/jquery-ui-1.7.2.custom.min.js'}" type="text/javascript"></script>
  <script src="@{'/public/javascripts/grid.locale-cn.js'}" type="text/javascript"></script>
  <script src="@{'/public/javascripts/jquery.jqGrid.min.js'}" type="text/javascript"></script>

  #{get 'moreScripts' /}
    </head>
    <body>
           #{if flash.error}
            <p class="error">${flash.error}</p>
        #{/if}
        #{if flash.success}
            <p class="success">${flash.success}</p>
        #{/if}
        
        <div id="main">
            #{doLayout /} 
        </div>
    </body>
</html>

和controller對應的View要加入jqGrid元件

N:\PlayFramework\play-1.1\members\app\views\EnhanceMemberOperation\index.html
#{extends 'main.html' /}
#{set title:'Home' /}

Member Data
<table id="scroll37"></table>
<div id="pscroll37" ></div>

<script type="text/javascript">
 
jQuery.fn.log = function(msg) {
    if (typeof console != "undefined")
        console.log("%s: %o", msg, this);
    return this;
};
 
 var lastsel2

jQuery("#scroll37").jqGrid({
    url:'@{memberList()}',
 datatype: "json",
 height: 400,
 width: 800,
 editable: true,
    colNames:['ID','firstName', 'lastName','gender', 'email'],

 colModel:[
     {
        name:'memberid',
        index:'memberid',
        align : "right",
        width : 50, 
        required : true,
  hidden: true, 
  editable: false, 
  editrules: { edithidden: false }, hidedlg: true
      },{
        name:'firstName',
        index:'firstName',
        width:100,
        editable : true,
        required : true,
  editrules:{required:true}
      },{
        name:'lastName',
        index:'lastName',
        width:100,
        editable : true,
        required : true
      },{
        name:'gender',
        index:'gender',
        width:50, 
        editable : true,
        edittype : 'select',
        editoptions:{value:"1:男;2:女"},
  formatter:function(cellvalue, options, row){
       if(cellvalue==1 || cellvalue=="男" ){
    return "男";
      }else{
          return "女";
     }
  },

        required : true
      },{
        name:'email',
        index:'email',
        width:150, 
        editable : true,
        required : true
      }
    ],
    rowNum:20,
 rowTotal: 100,
 rowList : [20,30,50],
 //scroll:2,
 headertitles: false,
 loadonce:false,
    mtype: "GET",
 editurl: '@{memberEdit()}', 
 rownumbers: true,
 rownumWidth: 40,
 gridview: true,
    pager: '#pscroll37',
    sortname: 'id',
    viewrecords: true,
    sortorder: "asc",
 caption: "Member Data",


 onSelectRow: function(id){
 
      if(id && id!==lastsel2){
 
        jQuery('#scroll37').saveRow(lastsel2);
  $("#scroll37").jqGrid('setGridParam', {editurl:'@{memberEdit()}?memberId='+$('#scroll37').jqGrid('getCell',id, 1)})
  jQuery('#scroll37').editRow(id,true);
        lastsel2=id;
      }
   
    }

});

jQuery("#scroll37").jqGrid('navGrid','#pscroll37',{del:true,add:true,edit:true});

</script>


Controller
由於新增了ajax的功能,所以controller 的部份要使用 renderJSON() 作輸出
N:\PlayFramework\play-1.1\members\app\controllers\EnhanceMemberOperation.java

package controllers;

import java.util.ArrayList;
import java.util.Hashtable;
import java.util.List;

import models.Member;
import models.MemberCard;
import play.data.validation.Required;
import play.mvc.Controller;

public class EnhanceMemberOperation extends Controller {
    public static void index() { 
        render();
   }

    public static void memberEdit(@Required String oper, long memberId,String firstName,String lastName ,Integer gender, String email) {
     if(validation.hasErrors()) {
            params.flash(); // add http parameters to the flash scope
            validation.keep(); // keep the errors for the next request
            System.out.println("ERROR: "+ validation.errors());
            index();
        }
        if (oper.equalsIgnoreCase("add")){
         new Member(firstName,lastName,gender,email).insert();
        }else if (oper.equalsIgnoreCase("del")){
         Member member = Member.findById(memberId);
         member.delete();
        }else if (oper.equalsIgnoreCase("edit")){
         Member member = Member.findById(memberId);
         member.firstName = firstName;
         member.lastName = lastName;
         member.gender = gender;
         member.email = email;
         member.update();
        }
        index();
    }
    
    public static void memberList(int page, int rows ,int sidx ,int  sord ) {

      System.out.println("進入memberList表單" +  params.get("page")+":" + params.get("rows"));
      int totalRecords= Member.all().count();
     int totalPage = (int) java.lang.Math.ceil(new Double(totalRecords) / new Double(rows));
     System.out.println("totalPage=" +  totalPage +" totalRecords=" + totalRecords);
     Hashtable ht = new Hashtable();
  ArrayList al = new ArrayList();
  
  int start = (page - 1) * rows;
  List<Member> members = Member.all().fetch(rows,start);
  for (int i=0;i<members.size();i++){
   Hashtable rowdata = new Hashtable();
   ArrayList columns = new ArrayList();
   columns.add(members.get(i).id);
   columns.add(members.get(i).firstName);
   columns.add(members.get(i).lastName);
   columns.add(members.get(i).gender);
   columns.add(members.get(i).email);
   rowdata.put("id",i);
   rowdata.put("cell",columns);
   al.add(rowdata);
  }

  ht.put("page",page);
  ht.put("total",totalPage);
  ht.put("records",totalRecords);
  ht.put("rows",al);
        renderJSON(ht);
      
    }

    
    public static void memberDelete(Long id) {
     Member member = Member.findById(id);
        notFoundIfNull(member); 
        member.delete();
        flash.success("The member %s has been deleted", member.firstName  );
        index();
    }
}



執行結果如下圖:

2011年6月9日 星期四

Regarding the select editor for jqGrid

http://www.ok-soft-gmbh.com/jqGrid/DependendSelects2.htm
這個範例是做Grid 中兩個Select Editor 的互動

2011年3月18日 星期五

jQuery DataGrid

總結一下今天的心得

2. SlickGrid under MIT licenses. Demo 沒有,要抓下來自己Run...而且文件少到靠北...可以從這裡找到一些資訊,有網友說可以參考 jqGrid 的文件??
3. SlickGrid 對大量資料有優勢,這裡有相關討論
4. Paging with scrollbar 就是常見的 log viewer 的作法,可以一直捲~邊捲邊取得資料....

2011年3月15日 星期二

ExtJS 和 jQuery 的比較

在網路上看了一些用ExtJS 做的範例,覺得蠻不錯的。
關於 ExtJS 和 jQuery 的比較我覺得這個網站提的蠻中肯的~
If your requirements are simple, publically accessible, and being done by web developers, then use jQuery. If this is a more complex situation, you have more hard core engineers, behind a username/password, then I suggest ExtJS.


這篇也寫的不錯,可以參考~

不過這兩篇沒提到的是 ExtJS 的授權協議。基本上 ExtJS 是商業軟體,如果要免費使用的話,只能用 ExtJs 2.0.2 之前的版本,因為他是用LGPL的授權方式。之後的版本是用GPL 的授權。有人認為GPL的授權是病毒授權,因為用了GPL的程式庫將造成本身的原始碼必須公開,當然這還是有爭議的,不過還是小心為妙。

2010年12月28日 星期二

jQuery EasyUI

這個東西差不多就是我想要的~
功能面都具備了,加上開發也蠻直覺的,可以進一步研究一下可以展現的效果。

不過這種東西還是擔心跨瀏覽器的問題。

能作到像這位大哥Blog的功能就很厲害了吧?

這有一些簡單的說明...
http://www.ityizhan.com/jquery-easyui-document/