方槍槍的java世界

          不要因為風雨飄落就停止了你的腳步,真正的得失就在你的心中。 做喜歡做的事,不輕言放棄!

          #

          javascript 學習(二)

          01、用構造函數創建對象
                  function Student(name,age,grade)   
                  {
                      this.name = name;
                      this.age = age;
                      this.grade = grade;
                  }

          02、直接創建對象
                  
                  var book = new Object();
                  
                  book.title = "精通Spring";
                  
                  book.chapter1= new Object();
                  book.chapter1.title="第一章";
                  book.chapter1.pages=20;
                  
                  book.chapter2 = {title:"第二章",pages:30};

                  delete book.chapter2;

          03、原型對象:每一個類都有一個原型對象,每一個該類的對象都繼承其原型對象的所有屬性;
                  要為一個類原型對象,需要將構造函數的prototype設置為適當的對象。
                  此后,用構造函數初始化一個對象的時候,javascript會自動將該對象作為新建對象的原型對象;
                  繼承在查詢一個屬性值時自動發生的,因此使用原型對象可以很大程度上減少每個對象對內存的需求量;

                  即使屬性是在對象創建后才添加到原型對象中,對象仍然能夠繼承這些屬性。
          04、類 方 法:通過設置類的一個屬性來實現;使用類名存取;類變量同理;
                  實例方法:通過設置原型對象的一個屬性實現;通過this來存取;
                  對象方法:通過設置某個對象的一個屬性來實現,只能由該對象來存取。


          posted @ 2008-04-07 23:42 做強大的自己 閱讀(155) | 評論 (0)編輯 收藏

          javascript 學習(一)

          01、引用javascript文件和將腳本文件直接插入到script標簽的效果相同;

          02、html的超鏈接標簽<a>的href屬性除了支持http、mailto協議外,還支持javascript協議。

          03、<head></head>之間引入腳本文件 ?

          04、全局變量是全局對象的一個屬性;所有預定義的函數和屬性都是全局變量的屬性;頂層代碼中使用this引用該全局對象;    

                  局部變量是局部對象的一個屬性;

                  可見所有javascript函數運行在自己獨有的執行環境中,而且具有自己的調用對象,并在調用對象中定義局部變量;

          05、原始類型使用值來進行操作的;

                  引用類型則是使用引用來進行操作的;

                  數字型和邏輯型數據都是由小的、固定數量的字節構成的原始類型;

                  對象、數組、函數都是引用類型,這些屬性可以包含任意多個屬性或元素,不像固定大小的原始數值那樣易于操作。另外,由于對象和數組所占用空間可能非常大,使用值來操作這些數據毫無意義,而且這樣做可能會產生占用大量內存空間的低效率的復制和比較。

          06、&nbsp; 空格

          07、函數的隱含參數數組對象arguments,用于處理不定個數的參數很方便。

          08、客戶端和服務器之間通信時,許多常見的非字母數字字符(如空格)不能以原來的格式傳輸,只允許使用較少的字母、數字和符號傳輸。為了使用其他字符,字符必須使用特殊的符號(%)和十六進制的ascii碼進行編碼,如空格是十六進制的20(ascii值十進制的32),其編碼為%20。在瀏覽器歷史記錄后url中可以見到這個符號。

                  encodeURI和decodeURI,URI編碼;

                  escape和unescape,對字符串編碼,不要對URI編碼,使用encodeURI。

          09、eval("表達式")執行動態表達式,效果和直接執行程序效果一樣;

           

           

          posted @ 2008-04-07 23:28 做強大的自己 閱讀(183) | 評論 (0)編輯 收藏

          cell 報表制作腳本舉例

           

          <%@ page contentType="text/html;charset=GBK"%>
          <%@ taglib uri="/tags/web-html" prefix="html"%>
          <%@ taglib uri="/tags/web-tianhe" prefix="templates"%>
          <%@ page import="java.math.BigDecimal"%>
          <%@ page import="java.util.List"%>
          <%@ page import="java.util.Map"%>
          <%@ page import="java.util.Date"%>


          <script language="Jscript">

          function setfilename()
          {
            filen="jsp/hr/personnel/Personnelreport.cll";  
            return filen;
          }
          function filldata()
          {
          <%
             List bodyList=(List)request.getAttribute("bodyList");  //表體數據
             Map headTailMap=(Map)request.getAttribute("headTailMap");  //表頭表尾數據
            
             int len = bodyList.size();
             String title= (String) headTailMap.get("title");//標題
                String userName=(String)headTailMap.get("userName");//制表人
                String date=(String)headTailMap.get("dateId");//制表時間
          %>
               sheet = <%=0%>;
            content_col=1;
            //設置某頁行數
            CellRpt.SetRows(<%=len+4+1%>,sheet);//設置某頁行數(行數,頁號)
            CellRpt.SetCols(15,sheet);//設置某頁列數(列數,頁號)
            CellRpt.PrintSetOrient(1);//設置進紙方式為橫放

            CellRpt.MergeCells(1,1,15,1);//將指定區域的單元格組合(區域起始點列號,行號,區域結束點列號,行號)
            CellRpt.SetCellFontStyle(1,1,sheet,2);//設置指定單元格的字體風格(列號,行號,頁號,字體風格)
             CellRpt.SetCellFontSize(1,1,sheet,20);//設置單元格字體大小(列號,行號,頁號,字號)
            CellRpt.SetCellAlign(1,1,sheet,36);//設置指定單元格的對齊方式(列號,行號,頁號,參數)
            CellRpt.S(1,1,sheet,"<%=title%>");

            CellRpt.MergeCells(1,2,1,2);
            CellRpt.SetCellFontStyle(1,2,sheet,3);
             CellRpt.SetCellFontSize(1,2,sheet,10);
            CellRpt.SetCellAlign(1,2,sheet,36);
            CellRpt.S(1,2,sheet,"部門");

            CellRpt.MergeCells(2,2,2,2);
            CellRpt.SetCellFontStyle(2,2,sheet,3);
             CellRpt.SetCellFontSize(2,2,sheet,10);
            CellRpt.SetCellAlign(2,2,sheet,36);
            CellRpt.S(2,2,sheet,"姓名");

            CellRpt.MergeCells(3,2,3,2);
            CellRpt.SetCellFontStyle(3,2,sheet,3);
             CellRpt.SetCellFontSize(3,2,sheet,10);
            CellRpt.SetCellAlign(3,2,sheet,36);
            CellRpt.S(3,2,sheet,"性別");

            CellRpt.MergeCells(4,2,4,2);
            CellRpt.SetCellFontStyle(4,2,sheet,3);
             CellRpt.SetCellFontSize(4,2,sheet,10);
            CellRpt.SetCellAlign(4,2,sheet,36);
            CellRpt.S(4,2,sheet,"年齡");

            CellRpt.MergeCells(5,2,5,2);
            CellRpt.SetCellFontStyle(5,2,sheet,3);
             CellRpt.SetCellFontSize(5,2,sheet,10);
            CellRpt.SetCellAlign(5,2,sheet,36);
            CellRpt.S(5,2,sheet,"政治面貌");

            CellRpt.MergeCells(6,2,6,2);
            CellRpt.SetCellFontStyle(6,2,sheet,3);
             CellRpt.SetCellFontSize(6,2,sheet,10);
            CellRpt.SetCellAlign(6,2,sheet,36);
            CellRpt.S(6,2,sheet,"學歷");

            CellRpt.MergeCells(7,2,7,2);
            CellRpt.SetCellFontStyle(7,2,sheet,3);
             CellRpt.SetCellFontSize(7,2,sheet,10);
            CellRpt.SetCellAlign(7,2,sheet,36);
            CellRpt.S(7,2,sheet,"專業技術名稱");

            CellRpt.MergeCells(8,2,8,2);
            CellRpt.SetCellFontStyle(8,2,sheet,3);
             CellRpt.SetCellFontSize(8,2,sheet,10);
            CellRpt.SetCellAlign(8,2,sheet,36);
            CellRpt.S(8,2,sheet,"職業技能名稱");

            CellRpt.MergeCells(9,2,9,2);
            CellRpt.SetCellFontStyle(9,2,sheet,3);
             CellRpt.SetCellFontSize(9,2,sheet,10);
            CellRpt.SetCellAlign(9,2,sheet,36);
            CellRpt.S(9,2,sheet,"出生日期");

            CellRpt.MergeCells(10,2,10,2);
            CellRpt.SetCellFontStyle(10,2,sheet,3);
             CellRpt.SetCellFontSize(10,2,sheet,10);
            CellRpt.SetCellAlign(10,2,sheet,36);
            CellRpt.S(10,2,sheet,"入職時間");
           
            CellRpt.MergeCells(11,2,11,2);
            CellRpt.SetCellFontStyle(11,2,sheet,3);
             CellRpt.SetCellFontSize(11,2,sheet,10);
            CellRpt.SetCellAlign(11,2,sheet,36);
            CellRpt.S(11,2,sheet,"家庭地址");
           
            CellRpt.MergeCells(12,2,12,2);
            CellRpt.SetCellFontStyle(12,2,sheet,3);
             CellRpt.SetCellFontSize(12,2,sheet,10);
            CellRpt.SetCellAlign(12,2,sheet,36);
            CellRpt.S(12,2,sheet,"辦公電話");
           
            CellRpt.MergeCells(13,2,13,2);
            CellRpt.SetCellFontStyle(13,2,sheet,3);
             CellRpt.SetCellFontSize(13,2,sheet,10);
            CellRpt.SetCellAlign(13,2,sheet,36);
            CellRpt.S(13,2,sheet,"移動電話");
           
            CellRpt.MergeCells(14,2,14,2);
            CellRpt.SetCellFontStyle(14,2,sheet,3);
             CellRpt.SetCellFontSize(14,2,sheet,10);
            CellRpt.SetCellAlign(14,2,sheet,36);
            CellRpt.S(14,2,sheet,"員工狀態");
           
               content_row=3;

          <%
            BigDecimal sumEmpNum = new BigDecimal(bodyList.size());

                  for(int i = 0;i < bodyList.size();i++){
                 Map  bodyMap = (Map) bodyList.get(i);
                 String orgName = (String)bodyMap.get("ORGAN_NAME");//部門
              String empName = (String)bodyMap.get("EMP_NAME");//員工姓名
              String sex = (String)bodyMap.get("SEX");//性別
              String policital = (String)bodyMap.get("POLICITAL_STATUS");//政治面貌
              String edu = (String)bodyMap.get("EDUCATION");//學歷
              String tName = (String)bodyMap.get("NAME");//專業技術名稱
              String skillName = (String)bodyMap.get("SKILL_POST_NAME");//職業技能名稱
              String birthday = (String)bodyMap.get("BIRTHDAY");//生日
              String entryDay = (String)bodyMap.get("ENTRY_ENTERPRISE_DAT");//入職時間
              String addr = (String)bodyMap.get("ADDRESS");//家庭住址
              String officePhone = (String)bodyMap.get("OFFICE_PHONE");//辦公電話
              String mobilePhone = (String)bodyMap.get("MOBILE_PHONE");//移動電話
              String state = (String)bodyMap.get("STATE");//員工狀態
              String ageStr = "";
              if(sex == null || "".equals(sex)){
               sex = "";
              }else{
               switch(Integer.parseInt(sex)){
               case 0 : sex="男";break;
               case 1 : sex="女";break;
               } 
              }
              if(policital == null || "".equals(policital)){
               policital = "";
              }else{
               switch(Integer.parseInt(policital)){
               case 1 : policital="工人";break;
               case 2 : policital="農民";break;
               case 3 : policital="知識分子";break;
               case 4 : policital="群眾";break;
               } 
              }
              if(edu == null || "".equals(edu)){
               edu = "";
              }else{
               switch(Integer.parseInt(edu)){
               case 1 : edu="小學";break;
               case 2 : edu="初中";break;
               case 3 : edu="高中";break;
               case 4 : edu="大學???;break;
               case 5 : edu="大學本科";break;
               case 6 : edu="碩士";break;
               case 7 : edu="博士";break;
               } 
              }
              if(skillName == null || "".equals(skillName)){
               skillName = "";
              }else{
               switch(Integer.parseInt(skillName)){
               case 1 : skillName="企業人力資源管理";break;
               case 2 : skillName="計算機操作";break;
               case 3 : skillName="倉儲工";break;
               case 4 : skillName="企業經營管理";break;
               case 5 : skillName="秘書";break;
               case 6 : skillName="物流管理";break;
               case 7 : skillName="卷煙商品營銷";break;
               case 8 : skillName="客戶服務管理";break;
               case 9 : skillName="企業信息管理";break;
               case 10 : skillName="汽車駕駛";break;
               case 11 : skillName="營業員";break;
               } 
              }
              if(birthday == null || "".equals(birthday)){
               birthday = "";
              }else{
               String yearBir = birthday.substring(0,4);
               String dateNow = new Date().toString();
               String yearNow = dateNow.substring(dateNow.length()-4,dateNow.length());
               int ageInt = Integer.parseInt(yearNow) - Integer.parseInt(yearBir);
               ageStr = String.valueOf(ageInt); 
              }
          %>
                  content_col=1;
             CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
            CellRpt.SetCellAlign(content_col,content_row,sheet,33);
            CellRpt.S(content_col,content_row,sheet,"<%=orgName%>");
            content_col++;

            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,33);
            CellRpt.S(content_col,content_row,sheet,"<%=empName%>");
            content_col++;

            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,33);
            CellRpt.S(content_col,content_row,sheet,"<%=sex%>");
            content_col++;

            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=ageStr%>");
            content_col++;

            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=policital%>");
            content_col++;

            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=edu%>");
            content_col++;

            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=tName%>");
            content_col++;

            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=skillName%>");
            content_col++;

            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=birthday%>");
            content_col++;
           
            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=entryDay%>");
            content_col++;
           
            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=addr%>");
            content_col++;
           
            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=officePhone%>");
            content_col++;
           
            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=mobilePhone%>");
            content_col++;
           
            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=state%>");

            content_row++;
          <%

          }
          %>
            content_col=1;
            CellRpt.MergeCells(content_col,content_row,content_col,content_row);
            CellRpt.SetCellFontStyle(content_col,content_row,sheet,0);
            CellRpt.SetCellAlign(content_col,content_row,sheet,33);
            CellRpt.S(content_col,content_row,sheet,"合計");

            content_col++;

            CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
             CellRpt.SetCellAlign(content_col,content_row,sheet,34);
            CellRpt.S(content_col,content_row,sheet,"<%=sumEmpNum%>(人)");//總人數

           
            content_row++;
           
           
            CellRpt.MergeCells(1,content_row,3,content_row);
            CellRpt.SetCellFontSize(1,content_row,sheet,10);
             CellRpt.SetCellAlign(1,content_row,sheet,33);
            CellRpt.S(1,content_row,sheet,"制表人:"+"<%=userName%>");

            CellRpt.MergeCells(12,content_row,14,content_row);
            CellRpt.SetCellFontSize(12,content_row,sheet,10);
             CellRpt.SetCellAlign(12,content_row,sheet,34);
            CellRpt.S(12,content_row,sheet,"制表日期:"+"<%=date%>");

             var line_rowBegin=2; //從第二行開始
            var line_rowEnd=CellRpt.getRows(sheet)-2; //畫到倒數第三行
            var line_colBegin=1; //從第一列開始
            var line_colEnd=CellRpt.getCols(sheet);//畫到最后一列
            CellRpt.DrawGridLine(line_colBegin, line_rowBegin, line_colEnd,line_rowEnd, 0, 2,-1);//所有框畫細線
           
            //打印設置
             CellRpt.PrintRange(1,1,CellRpt.getCols(sheet),CellRpt.getRows(sheet));
            CellRpt.PrintSetTopTitle(1,6);
            CellRpt.PrintSetBottomTitle(content_row+1,content_row+1);
            CellRpt.PrintSetOrient(1);//打印方向:1為橫向,0為縱向
          }

          </script>

          posted @ 2008-04-05 23:58 做強大的自己 閱讀(722) | 評論 (0)編輯 收藏

          SWT/JFace入門指南之初步體驗widget

          從Widget和Control開始

            Widget是Control的父類,而Control是我們使用的大多數部件的父類。

            在org.eclipse.swt.widgets中定義了眾多的widget,甚至我們前面介紹的Shell也被當成widget的一種。

            因為可用的widget如此之多,所以我大概沒有辦法全部一一介紹。在這一節中,我會介紹幾種常用的widget。相信善于觸類旁通的你通過這些極為簡略的介紹應該可以開始使用各種widget,在使用中不斷完善自己的認識。

            首先我們來介紹Widget。它是一個抽象類,也是所有widget的父類。通過介紹這個類,我們可以得出這所有widget的一些共有特性。

            Widget的方法中dispose()方法我們在以前曾經見到過,調用這個方法時候,所謂的接收者(receiver,譬如我們這樣寫:awidget.dispose(),那么awidget就是接收者,而這句話所處的對象稱為調用者)和接收者中所包含的其他widget會釋放它們所占用底層操作系統的資源。這也就是說你不必顯式地為程序中創建的每個widget進行dispose()調用,而只需要確保最外層的widget(比如Display)進行了dispose()就可以了。

            另外還可以通過isDisposed()判斷是否該widget(接收者)已經進行了dispose。

            Widget中的getStyle()方法得到widget的風格,而getDisplay()得到所處的Display對象。

            此外Widget中還有兩個重要方法getData()和setData(),這兩個方法允許我們為一個widget附加其他的信息。特別是在你需要跨模塊傳遞widget的時候,這個功能顯得非常有用。比如如果一個文本框中顯示了一段文章中的某句話,如果我們同時希望把這整篇文章的題目和作者附加上的話可以這樣寫:

            atext.setData("title","I Have A Dream");
            atext.setData("author","Martin Luther King");

            在程序的其他部分可以用atext.getData(“title”)得到這篇文章的題目,或者用atext.getData("author")得到作者。

            在前面我們提到過,Control是今后我們所使用大部分widget的父類。

            創建部件

            和創建其他java object一樣,我們通過使用new操作符創建部件的實例。有一點比較特殊的可能你需要使用帶參數的構造函數進行new操作。類似下面的程序:

            Text text=new Text(shell,SWT.CENTER);

            這種方法適用于幾乎所有的widget,其中第一個參數是父widget,也就是指明了該widget需要被放置道另外哪一個widget之中,而第二個參數是這個widget的風格。

            大小和位置

            僅僅創建一個部件并不足以讓你看到它,因為一個部件初始的長和寬都是0。你還需要設定它的大小。你可以用setSize()或者setBounds()方法手動設定部件的大小,也可以讓系統自動調整部件的大小到一個合適的值,這個值也被成為首選尺寸(preferred size)。

            可以通過調用pack()方法讓系統調整控件大小。如果你希望系統自動調整,那么你需要首先設定控件需要表達的內容。舉個例子來說,如果你的部件是一個文本框或者標簽,你應該首先設定它所要顯示的文本,這樣系統可以通過文本的長度計算。

            對于部件的位置,同樣可以使用setLocation()或者setBounds()進行設定。

            這里值得一提的是所謂的bounds,其實bounds可以看成是大小和尺寸的綜合。比如setBounds(int x, int y,int width,int height)的參數中,x和y描述的是位置信息,而width和height描述了大小。

            隱藏與失效

            通過部件的setVisible方法可以控制部件進行隱藏或是顯示。通過setEnabled方法可以控制部件是否有效。一個無效的部件不會對用戶的任何動作作出響應。這兩個方法的參數都是布爾型的。

            提示文本

            可以通過setToolTipText()方法設定部件的提示文本。

            幾種常用的部件

            Label

            標簽用來顯示靜態的文本或者圖像。關于圖像和色彩我會在后面的部分進行介紹。

            標簽可以使用SWT.CENTER, SWT.LEFT, SWT.RIGHT中的一種指明文本的對齊方式(居中對齊,左對齊,右對齊)。

            你也可以通過設置標簽屬性為SWT. SEPARATOR 使標簽成為一條分隔符。

            Text就是最簡單的文本框,與標簽一樣,我們可以通過設定它的風格來表示它的對齊方式(SWT.CENTER,SWT.LEFT,SWT.RIGHT),另外還有其他一些用于文本支持的方法,比如insert(),paster(),copy(),setSelection(),selectAll()等,這些方法在后面介紹swt事件模式會進行更詳細的介紹。

            Button

            在swt中,Button并不僅僅是按鈕。構造時候定義的風格不同,所體現出的外觀也不一樣。

            如果風格定義成SWT.PUSH,它就是一個普通的按鈕。

            如果定義為SWT.TOGGLE,它在被按下以后會保持按下的形狀(而不會彈起來),直到鼠標再次在上面按一下才會回復彈起的形狀。

            如果風格定義為SWT.ARROW,它是一個帶箭頭的按鈕,箭頭的指向可以選擇SWT.LEFT,SWT.RIGHT,SWT.UP,SWT.DOWN中的一個。

            如果定義為SWT.CHECK,它是一個復選框。

            如果定義為SWT.RADIO,它是一個單選框。
            

          posted @ 2008-04-05 23:06 做強大的自己 閱讀(204) | 評論 (0)編輯 收藏

          搭建 strut2+spring2 on java5 的開發框架(一)

           從http://struts.apache.org/2.x/下載struts2.0.11。
           
           使用tomcat5.0會報錯如下:
           2008-04-05 20:00:20 StandardContext[/tianhe]Exception starting filter struts2
          javax.xml.transform.TransformerFactoryConfigurationError: Provider org.apache.xalan.processor.TransformerFactoryImpl not found
           at javax.xml.transform.TransformerFactory.newInstance(Unknown Source)
             
          解決 辦法1:
           拷貝xalan.jar,xercesImpl.jar,serializer.jar,xml-apis.jar 到 應用的tomcat的common\endorsed目錄
          解決 辦法2:     
           升級到tomcat5.5

          這種異常很惡心.
          出現的原因是因為jdk版本和tomcat版本的不匹配造成的.
          解決的原因是用匹配的版本.
          在此.推薦jdk1.5+jdk5.5.20搭配.

          posted @ 2008-04-05 20:13 做強大的自己 閱讀(163) | 評論 (0)編輯 收藏

          僅列出標題
          共4頁: 上一頁 1 2 3 4 
          主站蜘蛛池模板: 突泉县| 苗栗县| 乐昌市| 烟台市| 迁安市| 墨竹工卡县| 桂林市| 宕昌县| 涞源县| 武汉市| 读书| 金坛市| 济阳县| 金秀| 嘉义县| 建湖县| 安吉县| 长兴县| 南昌县| 夹江县| 民丰县| 子洲县| 宣恩县| 许昌县| 濉溪县| 神池县| 昆明市| 临颍县| 黄大仙区| 东兰县| 循化| 宁明县| 乌兰察布市| 温泉县| 宿州市| 桂阳县| 昌吉市| 黄骅市| 定南县| 蒙阴县| 金乡县|