700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > go语言使用go-sciter创建桌面应用(八) 窗口显示时 自动加载后端数据。

go语言使用go-sciter创建桌面应用(八) 窗口显示时 自动加载后端数据。

时间:2020-09-14 04:56:35

相关推荐

go语言使用go-sciter创建桌面应用(八) 窗口显示时 自动加载后端数据。

有些时候我们需要在窗口创建并显示时,加载一些后端的配置,这就需要用到view提供的几个事件。

/docs/content/sciter/View.htm

statechange 状态改变时,最大化,最小化,显示,隐藏,会触发事件回调。

activate 窗口激活或停用时,可以理解为获取焦点或失去焦点,触发事件回调。

demo.go的代码如下:

package mainimport ("fmt""log""path/filepath""database/sql""encoding/json"_ "/go-sql-driver/mysql""/sciter-sdk/go-sciter""/sciter-sdk/go-sciter/window")type User struct {Name string `json:"name"`;Pwd string `json:"pwd"`;}func defFunc(w *window.Window) {//注册dump函数方便在tis脚本中打印数据w.DefineFunction("dump", func(args ...*sciter.Value) *sciter.Value {for _, v := range args {fmt.Print(v.String() + " ");}fmt.Println();return sciter.NullValue();});//定义函数,用于tis脚本中加载用户名和密码w.DefineFunction("LoadNameAndPwd", func(args ...*sciter.Value) *sciter.Value {//连接数据库db, err := sql.Open("mysql", "root:@tcp(127.0.0.1:3306)/test?charset=utf8");if err != nil {fmt.Println(err);}//关闭数据库defer db.Close();//查询一行数据name := "";pwd := "";rows := db.QueryRow("select name,pwd from tb_users where id = ?", 1);rows.Scan(&name, &pwd);//构建一个jsonuser := User{Name: name, Pwd: pwd};data, _ := json.Marshal(user);//将json返回,tis脚本中接收该值return sciter.NewValue(string(data));});}func main() {w, err := window.New(sciter.SW_TITLEBAR|sciter.SW_RESIZEABLE|sciter.SW_CONTROLS|sciter.SW_MAIN|sciter.SW_ENABLE_DEBUG,nil);if err != nil {log.Fatal(err);}//加载文件filepath, _ := filepath.Abs("./demo.html");err = w.LoadFile(filepath);//设置标题w.SetTitle("加载数据");//定义函数defFunc(w);//显示窗口w.Show();//运行窗口,进入消息循环w.Run();}

demo.html的代码如下:

<!DOCTYPE html><html lang="zh-CN"><head><meta charset="UTF-8"></head><body>用户名:<input type="text" id="name" value=""><br>密码:<input type="text" id="pwd" value=""></body><script type="text/tiscript">//窗口被激活或停用时,触发回调,可以理解为获得焦点view.on("activate", function(type) {//调用go中定义的方法LoadNameAndPwdvar data = view.LoadNameAndPwd();//解析json,转换成对象data = JSON.parse(data);$(#name).value = data.name;$(#pwd).value = data.pwd;});//窗口状态发生改变时,触发回调,最大化,最小化,隐藏,显示view.on("statechange", function() {//调用go中定义的方法LoadNameAndPwdvar data = view.LoadNameAndPwd();//解析json,转换成对象data = JSON.parse(data);$(#name).value = data.name;$(#pwd).value = data.pwd;});</script></html>

最后的显示结果如下:

我的数据库表数据如下:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。