Go GUI---lxn/walk 自带demo学习---22.webview

本文展示了如何在Go语言中使用walk库创建一个简单的WebView应用,用户可以输入URL并回车加载页面。代码中实现了LineEdit与WebView的交互,当用户按下回车键时,WebView会跳转到LineEdit中输入的URL。尽管当前实现存在优化空间,例如图标处理函数仅对特定URL返回图标,但这个例子为理解Go中的GUI编程和WebView集成提供了一个基础起点。
摘要由CSDN通过智能技术生成

 

简单说明:webview的简单使用,存在许多待优化的地方,┭┮﹏┭┮

webview.go

// Copyright 2010 The Walk Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.

package main

import (
	"strings"

	"github.com/lxn/walk"
	. "github.com/lxn/walk/declarative"
)

func main() {
	var le *walk.LineEdit
	var wv *walk.WebView

	MainWindow{
		Icon:    Bind("'../img/' + icon(wv.URL) + '.ico'"),
		Title:   "Walk WebView Example'",
		MinSize: Size{800, 600},
		Layout:  VBox{MarginsZero: true},
		Children: []Widget{
			LineEdit{
				AssignTo: &le,
				Text:     Bind("wv.URL"),
				OnKeyDown: func(key walk.Key) {
					if key == walk.KeyReturn {
						wv.SetURL(le.Text())
					}
				},
			},
			WebView{
				AssignTo: &wv,
				Name:     "wv",
				URL:      "https://github.com/lxn/walk",
			},
		},
		Functions: map[string]func(args ...interface{}) (interface{}, error){
			"icon": func(args ...interface{}) (interface{}, error) {
				if strings.HasPrefix(args[0].(string), "https") {
					return "check", nil
				}

				return "stop", nil
			},
		},
	}.Run()
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Walk库中,可以使用`TabPage`和`TabWidget`控件来创建和管理选项卡。下面是一个简单的示例代码,演示如何初始化包含两个选项卡的`TabWidget`: ```go package main import ( "github.com/lxn/walk" . "github.com/lxn/walk/declarative" ) func main() { // 创建一个新的主窗口 mainWindow := new(MyMainWindow) // 创建一个新的TabWidget tabWidget := new(walk.TabWidget) // 创建第一个选项卡 tabPage1 := walk.NewTabPage() tabPage1.SetTitle("Tab Page 1") tabPage1.SetLayout(walk.NewVBoxLayout()) // 添加一些控件到第一个选项卡中 tabPage1.Layout().Add(walk.NewLabel(mainWindow)) tabPage1.Layout().Add(walk.NewPushButton(mainWindow)) // 创建第二个选项卡 tabPage2 := walk.NewTabPage() tabPage2.SetTitle("Tab Page 2") tabPage2.SetLayout(walk.NewVBoxLayout()) // 添加一些控件到第二个选项卡中 tabPage2.Layout().Add(walk.NewLabel(mainWindow)) tabPage2.Layout().Add(walk.NewCheckBox(mainWindow)) // 将两个选项卡添加到TabWidget中 tabWidget.Pages().Add(tabPage1) tabWidget.Pages().Add(tabPage2) // 创建一个新的主布局,并将TabWidget添加到其中 mainLayout := VBox{ MarginsZero: true, Children: []Widget{ tabWidget, }, } // 创建主窗口的声明式描述 mainWindow.Desc = &MainWindow{ Title: "My App", MinSize: Size{600, 400}, Layout: mainLayout, AssignTo: &mainWindow.MainWindow, } // 运行应用程序 mainWindow.Run() } // 定义一个新的主窗口类型 type MyMainWindow struct { *walk.MainWindow } ``` 在这个示例中,我们创建了一个`TabWidget`,并向其中添加了两个选项卡。每个选项卡都包含一些基本控件,例如`Label`,`PushButton`和`CheckBox`,以演示如何将控件添加到选项卡中。最后,我们将`TabWidget`添加到一个主布局中,并将其分配给主窗口的`Desc`属性。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值