将图像作为输入框的背景

Posted

技术标签:

【中文标题】将图像作为输入框的背景【英文标题】:put an image as the background of an input box 【发布时间】:2013-10-17 10:16:09 【问题描述】:

我想将图像放入msgbox。搜索后发现不可能,所以我决定将图像放入msgbox 输入框的背景中。但我找不到如何做到这一点:

    自定义输入框去掉边框,改变背景颜色

【问题讨论】:

可能使用 javascript 我想在 vbs 文件上使用它。 那么我很确定你不走运。 VBScript 并不是一种强大的语言。 【参考方案1】:

内置的InputBox 函数不支持自定义背景。不过,您可以使用Internet Explorer COM object 构建自定义对话框:

Set ie = CreateObject("InternetExplorer.Application")

ie.Navigate "about:blank"
ie.document.title = "some title"
ie.ToolBar        = False
ie.Resizable      = False
ie.StatusBar      = False
ie.Width          = 300
ie.Height         = 150

Set style = ie.document.CreateStyleSheet()
style.AddRule "body", "background-image: url('C:\path\to\your.jpg')"
Set style = Nothing

Do Until ie.ReadyState = 4 : WScript.Sleep 100 : Loop

ie.document.body.innerhtml = "<p><input type='text' id='userinput'></p>" _
  & "<p><input type='hidden' id='OK' name='OK' value='0'>" _
  & "<input type='submit' value='OK' onClick='VBScript:OK.Value=1'>" _
  & "<input type='submit' value='Cancel' onClick='VBScript:OK.Value=-1'></p>"
ie.Visible = True
ie.document.all.userinput.focus

Do While ie.document.all.OK.value = 0 : WScript.Sleep 100 : Loop

If ie.document.all.OK.value = 1 Then
  'user pressed [OK]
Else
  'user clicked [Cancel]
End If

当然,这只是一个非常基本的示例,因此您很可能需要进一步自定义样式以及 HTML 代码。一种可能的改进是以data URI 的形式包含背景图像:

style.AddRule "body", "background-image: url(data:image/jpeg;base64,/9j/4AA...')

这样您就不必为背景引用外部文件。您可以使用免费的在线编码器将图像文件编码为 base64,例如 this one。

【讨论】:

以上是关于将图像作为输入框的背景的主要内容,如果未能解决你的问题,请参考以下文章

OCR 的背景图像清理

豆瓣首页话题输入框的实现

CSS如何在输入框的末尾有一个图像

input输入框的各种样式

将图像放入输入框

input输入框的背景图片也可以这样玩