文章詳情頁(yè)
初次感覺(jué)java面向?qū)ο蟮乃枷?/h1>
瀏覽:59日期:2024-06-17 15:10:31
內(nèi)容: /*創(chuàng)建了這個(gè)例子,初次感覺(jué)啦java的面向?qū)ο蟮木瑁琷table只用來(lái)顯示,而使用模板來(lái)改變jtable的屬性,實(shí)現(xiàn)了表格的顯示與設(shè)置分離*/import javax.swing.*;import java.awt.*;import javax.swing.table.*;import java.util.*;import java.awt.event.*;import javax.swing.table.TableColumn;import java.sql.*;import sun.jdbc.odbc.JdbcOdbcDriver;class Typec extends JFrame{ //窗體及窗體控件 JPanel pnla=null; JPanel pnlb=null; JTable table=null; TestModela md=null; TestModelb mdb=null; TableColumn tc=null; javax.swing.JComboBox jc=null; javax.swing.JCheckBox jboxa=null; javax.swing.JCheckBox jboxb=null; DataBase db=new DataBase(); //連接sql數(shù)據(jù) javax.swing.JScrollPane js; JButton but; JTextField jt1=null; JTextField jt2=null; JTextField jt3=null; JTextField jt4=null; JTextField jt5=null; //Object數(shù)組構(gòu)造jtable Object[][] a=new Object[2][3]; Object[] b={'a','b','c'}; //Object數(shù)組構(gòu)造jtable Object[][] aa={{'a','b','c'}}; //vector數(shù)組構(gòu)造jtable Vector va,vb,vc; //實(shí)現(xiàn)功能 //1)將Object數(shù)組構(gòu)造的jtable添加到窗體上去 //2)將JTable的第一列的屬性改為文本框,第二列的屬性改變?yōu)橄吕?void addObject() { table=new JTable(a,b); tc=new TableColumn(); jt1=new javax.swing.JTextField(10); jt1.setBackground(Color.red); jc=new JComboBox(); jc.addItem('男'); jc.addItem('女'); tc=table.getColumnModel().getColumn(1); tc.setCellEditor(new DefaultCellEditor(jt1)); tc=table.getColumnModel().getColumn(2); tc.setCellEditor(new DefaultCellEditor(jc)); js=new JScrollPane(table); this.getContentPane().add(js,BorderLayout.CENTER); this.setSize(700,350); //必須先添加后顯示,不然會(huì)不正常的顯示的 this.show(); } //實(shí)現(xiàn)功能 //1)使用Object模板來(lái)創(chuàng)建JTable //2) 實(shí)現(xiàn)JTable的表格邊框的隱藏和顯示b及指定列的隱藏和顯示 void addObjectMd() { pnla=new JPanel(); jt1=new JTextField(10); but=new JButton('設(shè)置行高'); but.addActionListener(new butsj()); jboxa=new JCheckBox('隱藏',false); jboxa.addItemListener(new MyItemListener()); jboxb=new JCheckBox('刪除',false); jboxb.addItemListener(new MyItemListener()); pnla.add(jt1); pnla.add(but); pnla.add(jboxa); pnla.add(jboxb); md=new TestModela(aa,b); //使用模板必須數(shù)組里有值 table=new JTable(md); js=new JScrollPane(table); pnlb=(JPanel)this.getContentPane(); pnlb.setLayout(new BorderLayout()); pnlb.add(pnla,BorderLayout.NORTH); pnlb.add(js,BorderLayout.CENTER); this.setSize(700,350); //必須先添加后顯示,不然會(huì)不正常的顯示的 this.show(); } void addVector() { vc=new Vector(); vc.add('va'); vc.add('vb'); vc.add('vc'); va=new Vector(); va.add(vc); vb=new Vector(); vb.add('va'); vb.add('vb'); vb.add('vc'); table=new JTable(va,vb); js=new JScrollPane(table); this.getContentPane().add(js,BorderLayout.CENTER); this.setSize(700,350); //必須先添加后顯示,不然會(huì)不正常的顯示的 this.show(); } void addVectorMd() //czVector模板類(lèi) { //定義表中的一條數(shù)據(jù),相當(dāng)于一個(gè)一維數(shù)組 vc=new Vector(); vc.add('va'); vc.add('vb'); vc.add('vc'); vc.add(new Boolean(false)); va=new Vector(); //將產(chǎn)生的數(shù)據(jù)增加到va中去 va.add(vc); vb=new Vector(); //定義JTable的標(biāo)題 vb.add('va'); vb.add('vb'); vb.add('vc'); vb.add('vd'); mdb=new TestModelb(va,vb); table=new JTable(mdb); //表格已構(gòu)造完畢 js=new JScrollPane(table); jt1=new JTextField(10); jt2=new JTextField(10); jt3=new JTextField(10); jt4=new JTextField(10); but=new JButton('增加'); but.addActionListener(new butsj()); pnla=new JPanel(); pnla.add(jt1); pnla.add(jt2); pnla.add(jt3); pnla.add(jt4); pnla.add(but); pnlb=(JPanel)this.getContentPane(); pnlb.setLayout(new BorderLayout()); pnlb.add(pnla,BorderLayout.NORTH); pnlb.add(js,BorderLayout.CENTER); this.setSize(700,350); //必須先添加后顯示,不然會(huì)不正常的顯示的 this.show(); } void addVectorSql() { DataBase.FillVector('select * from students'); va=DataBase.data; //獲取數(shù)據(jù)庫(kù)中的行數(shù)據(jù) vb=DataBase.title; //獲取數(shù)據(jù)庫(kù)中的標(biāo)題 mdb=new TestModelb(va,vb); table=new JTable(mdb); js=new JScrollPane(table); pnla=new JPanel(); pnlb=(JPanel)this.getContentPane(); pnlb.setLayout(new BorderLayout()); pnlb.add(pnla,BorderLayout.NORTH); pnlb.add(js,BorderLayout.CENTER); this.setSize(700,350); //必須先添加后顯示,不然會(huì)不正常的顯示的 this.show(); } ////處理Click事件 private class butsj implements ActionListener { public void actionPerformed(ActionEvent e) { if((e.getSource()==but)&&but.getText().equals('增加')) { vc=new Vector(); vc.add(jt1.getText()); vc.add(jt2.getText()); vc.add(jt3.getText()); vc.add(new Boolean(jt4.getText().equalsIgnoreCase('true')));//將此 String 與另一個(gè) String 進(jìn)行比較,不考慮大小寫(xiě)。 mdb.AddRow(vc); } else if((e.getSource()==but)&&but.getText().equals('設(shè)置行高')) { int h=Integer.parseInt(jt1.getText());//得到輸入的值 if(h>0) table.setRowHeight(h);//設(shè)置table的行高 } }}//處理CheckBox 的選中事件 private class MyItemListener implements ItemListener { public void itemStateChanged(ItemEvent e) { //先判斷事件源 再判斷事件源是否被選中 if(e.getSource()==jboxa) if(jboxa.isSelected()) { //設(shè)置是否顯示表格線 table.setShowHorizontalLines(true); table.setShowVerticalLines(true); } else { table.setShowHorizontalLines(false); table.setShowVerticalLines(false); } //是否刪除分?jǐn)?shù)列 if(e.getSource()==jboxb) if(jboxb.isSelected())//是否選中 { tc=table.getColumnModel().getColumn(2); table.getColumnModel().removeColumn(tc); table.updateUI(); } else { table.getColumnModel().addColumn(tc); } } } }//這是Typec的右括弧,不要搞混啦//使用Object創(chuàng)建jtable模板class TestModela extends javax.swing.table.DefaultTableModel{ Object[][] data; Object[] title; TestModela(Object[][] d,Object[] t) { super(d,t); this.data=d; this.title=t; } public Object getValueAt(int r,int c) { return data[r][c];//得到r行c列的數(shù)據(jù) } public Class getColumnClass(int c) { //將不同的數(shù)據(jù)類(lèi)型 //以對(duì)應(yīng)的形式來(lái)顯示,大家可以比較這個(gè)例子中的顯示 //和前幾個(gè)例子的區(qū)別 return data[0][c].getClass(); } //設(shè)置r行,c列的值為 value //當(dāng)用戶在修改JTable中的數(shù)據(jù)時(shí),能自動(dòng)調(diào)用,并修改data中的數(shù)據(jù) public void setValueAt(Object value, int r,int c) { data[r][c]=value; }}//使用Vector創(chuàng)建jtable模板//對(duì)于JTable來(lái)說(shuō),它是一個(gè)二維結(jié)構(gòu),表中的整個(gè)數(shù)據(jù)由一個(gè)Vector//表中的每一行也是一個(gè)Vectorclass TestModelb extends javax.swing.table.DefaultTableModel{ Vector a; Vector b; TestModelb(Vector a,Vector b) { super(a,b); this.a=a; this.b=b; } public Object getValueAt(int c,int b) //得到每一列的數(shù)據(jù) { Vector v=(Vector)a.get(c);//取出可變數(shù)組中的數(shù)據(jù) return v.get(b); //得到每一行沒(méi)一列的值 } public Class getColumnClass(int c) { Vector v=(Vector)a.get(0); return v.get(c).getClass(); //將字符串變成各中類(lèi)型的數(shù)據(jù) } public boolean isCellEditable(int r,int c) { //除了第二列不能修改 //其它都可能修改 if(c==2) return false; return true; } //在自定義的TableModel中重寫(xiě)了AddRow方法 //向data中增加一個(gè)Vector,相當(dāng)于增加了一條記錄 public void AddRow(Vector row) { a.add(row); this.fireTableDataChanged();//通知所有偵聽(tīng)器,表的所有行單元格值可能已更改,如果不調(diào)用,將不會(huì)更改 } //???????????????????如何實(shí)現(xiàn)刪除行呢}/*// 在pubs數(shù)據(jù)庫(kù)中建一個(gè)表studentscreate table students(st_xh varchar(10),st_name varchar(10),st_age int)insert into studentsvalues('1000 0001','小王',25) 再建一個(gè)Odbc數(shù)據(jù)源test 聯(lián)結(jié)pubs*/ class DataBase //cz數(shù)據(jù)庫(kù)類(lèi) { public static Connection conn=null;//這是一個(gè)連接對(duì)象 public static ResultSet rs=null;//這是一個(gè)記錄集對(duì)象 public static Statement st=null;//這是一個(gè)語(yǔ)名對(duì)象 public static PreparedStatement pst=null;//執(zhí)行帶參數(shù)據(jù)的語(yǔ)句 public static CallableStatement cst=null;//執(zhí)行存儲(chǔ)過(guò)程 public static ResultSetMetaData rsmd=null;//得到記錄集的原信息 public static Vector data,title,row; //在構(gòu)造函數(shù)中去聯(lián)結(jié)數(shù)據(jù)庫(kù) public DataBase() { data=new Vector(); title=new Vector(); //必須使用異常捕獲,不然程序?qū)?bào)錯(cuò) try{ Class.forName('sun.jdbc.odbc.JdbcOdbcDriver'); conn=DriverManager.getConnection('jdbc:odbc:test','sa','sa'); st=conn.createStatement(); }catch(SQLException e) { e.printStackTrace(); }catch(Exception e) { e.printStackTrace(); } } //根據(jù)strSql來(lái)向兩個(gè)集合增加數(shù)據(jù) //data中存放表中的每條記錄,每條記錄也放入一個(gè)Vector中 //title中存放表的列的信息,根據(jù)ResultSetMetaData來(lái)提供 public static void FillVector(String strSql) { int s; int fieldCount; try{ data.clear(); title.clear(); rs=st.executeQuery(strSql);//得到結(jié)果集 rsmd=rs.getMetaData();//得到結(jié)查集的原數(shù)據(jù) fieldCount=rsmd.getColumnCount(); while(rs.next()) { row=new Vector(); for(int i=0;i60) row.add(new Boolean(true)); else row.add(new Boolean(false)); data.add(row); System.out.println(data.size()); } for(int i=0;i
標(biāo)簽:
Java
相關(guān)文章:
1. 原創(chuàng)-關(guān)于java中的對(duì)象序列化2. 詳解JSP 內(nèi)置對(duì)象request常見(jiàn)用法3. Java 如何從spring容器中獲取注入的bean對(duì)象4. ASP中解決“對(duì)象關(guān)閉時(shí),不允許操作。”的詭異問(wèn)題……5. Django中Q查詢及Q()對(duì)象 F查詢及F()對(duì)象用法6. 淺析Java 對(duì)象引用和對(duì)象本身7. ASP基礎(chǔ)知識(shí)Command對(duì)象講解8. Java之JSP教程九大內(nèi)置對(duì)象詳解(中篇)9. Python 轉(zhuǎn)移文件至云對(duì)象存儲(chǔ)的方法10. jsp Response對(duì)象頁(yè)面重定向、時(shí)間的動(dòng)態(tài)顯示
1. 原創(chuàng)-關(guān)于java中的對(duì)象序列化2. 詳解JSP 內(nèi)置對(duì)象request常見(jiàn)用法3. Java 如何從spring容器中獲取注入的bean對(duì)象4. ASP中解決“對(duì)象關(guān)閉時(shí),不允許操作。”的詭異問(wèn)題……5. Django中Q查詢及Q()對(duì)象 F查詢及F()對(duì)象用法6. 淺析Java 對(duì)象引用和對(duì)象本身7. ASP基礎(chǔ)知識(shí)Command對(duì)象講解8. Java之JSP教程九大內(nèi)置對(duì)象詳解(中篇)9. Python 轉(zhuǎn)移文件至云對(duì)象存儲(chǔ)的方法10. jsp Response對(duì)象頁(yè)面重定向、時(shí)間的動(dòng)態(tài)顯示
排行榜
