?? 動態創建數據窗.txt
字號:
動態創建數據窗原理及實現
作者:流方 2000.05.09 閱讀:409
[返回目錄]
在實際應用中,經常需要根據用戶需求來動態創建數據窗,一般方法是這樣的。
在一個window中加入一個數據窗控件,如dw_new,但是該數據窗沒有data object,(空白的)
就可以用以下語法來創建:
dw_new.create(ls_syntax,ls_error) // 創建語法,錯誤信息
ls_syntax可以用以下三種方法來形成:
一、動態由sql語法創建:
// 連接到pb的example數據庫
string ls_sql,ls_syntax,ls_error
ls_syntax = 'select * from department'
ls_syntax = sqlca.SyntaxFromSQL(ls_sql,'style(type=grid)',ls_error)
if len(ls_error) >0 then
messagebox('Error','SyntaxFromSQL Error:~r'+ls_error)
else
dw_new.create(ls_syntax,ls_error)
if len(ls_error) >0 then
MessageBox("Error", "Create have these errors: ~r" + ls_error)
else
dw_new.settransobject(sqlca)
dw_new.retrieve()
end if
end if
二、由另一個數據窗的syntax來創建
string ls_syntax,ls_error
ls_syntax = dw_test.describe('datawindow.syntax')
dw_new.create(ls_syntax,ls_error)
if ls_error <> '' then
messagebox('Create Error',ls_error)
else
dw_new.settransobject(sqlca)
dw_new.retrieve()
end if
三、讀取psr文件來創建
樣例
string ls_syntax,ls_error,ls_ret
ls_ret = char(13)+char(10) //回車鍵
int li_fileNum
long li_length
li_FileNum = FileOpen("efef.psr",Streammode!, read!, shared!, Replace!)
// 以下是pb5的代碼
if li_filenum >0 then
FileSeek(li_FileNum, 158, FromBeginning!)
li_length = fileRead(li_filenum,ls_syntax)
end if
fileclose(li_filenum)
if li_length = 0 then return
ls_syntax = "release 5;"+ls_ret+ls_syntax
//截掉ls_syntax中的數據部分,5.0以"sparse(names="dept_name?) "作為參考位置
//6.0以html(作為參考位置
long pos1,pos2
pos1 = pos(ls_syntax,'sparse(names="',1)
pos2 = pos(ls_syntax,'"',pos1 +16)
ls_syntax = left(ls_syntax,pos1) + mid(ls_syntax,pos1 +1,pos2 - pos1 +1)
dw_New.create(ls_syntax,ls_error)
if ls_error <> '' then
messagebox('Create Error',ls_error)
else
dw_new.settransobject(sqlca)
dw_new.retrieve()
end if
//pb6,pb7的代碼可以參照pb5自己寫,只是文件頭和數據窗結束標記不同而已。
流方
2000/05/09
PB中使用Web Browser控件步驟:
在pb的某窗口中加入OLE對象,選擇Insert control(插入控件),然后選中"Microsoft WEB 瀏覽器",就可以在這個窗口直接使用IE瀏覽器控件了。
常用函數:(對這個ole控件取名叫ole_web)
ole_web.object.navigate(string ls_url) //瀏覽某url
ole_web.object.goback() //回退
ole_web.object.goforward() //前進
常用事件:
documentcomplete : url請求的頁面完成
常用屬性:
ole_web.object.width
ole_web.object.height
詳細的屬性,函數、事件可以參考PB中的 browser 工具中的ole對象察看來得到。
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -