element库
一、获取HTML节点对象
element对象就是网页上的HTML节点对象,通过web窗体提供的函数在web窗体上获取。
读取element对象的方法请参考:web窗体-读取element节点对象。
二、删除HTML节点对象
element.del(ele)
立即释放ele对象。并不会删除ele这个变量(ele指向无效的对象)。
ele = nil;
立即删除ele变量,等待垃圾收集释放ele引用的HTML节点对象。
三、检测节点是否有效
ok = ele:ok()
检测ele对象是否是一个有效的标签
四、HTML节点属性
str = ele:tag()
读取HTML节点的标签名
str = ele:id()
读取HTML节点的id属性
str = ele:class()
读取HTML节点的class属性
str = ele:getAttribute("属性名")
获取HTML节点指定的属性
ele:setAttribute("属性名","属性值")
设置HTML节点指定的属性
x,y,cx,cy = ele:getRect()
返回值为表示节点屏幕位置的左坐标(x),上坐标(y),宽度(cx),高度(cy)。
ele2 = ele:parent()
返回父节点
tab = { ele:childs() }
读取一个element的所有子节点,返回一组element对象(一个或多个返回值)。
可以把所有的返回值放到表构造器{}中生成一个table数组。
四、HTML节点内容
str = ele:getHtml()
获取HTML节点全部源代码(outerHTML)
ele:setHtml("HTML代码")
设置HTML节点全部源代码(outerHTML)

使用 ele:setHtml函数或者ele:setText函数修改HTML节点以后,必须调用wb:getEle函数重新读取节点。
str = ele:getHtmlin()
获取HTML节点包含源代码(innerHTML)
ele:setHtmlin("HTML代码")
设置HTML节点包含源代码(innerHTML)
ele:setTextin 设置的是HTML标签内部的HTML代码
<a>这个中间的部份就是所谓的Htmlin</a>
str = ele:getText()
获取Text节点全部文本(outerText)
ele:setText("文本")
设置Text节点全部文本(outerText)
str = ele:getTextin()
获取Text节点包含文本(innerText)
ele:setTextin("文本")
设置Text节点包含文本(innerText)
ele:setTextin 设置的是HTML标签内部的文本
<a>这个中间的部份就是所谓的Textin</a>
ele:adjacentHtml("beforeBegin","HTML代码")
ele:adjacentHtml("afterBegin","代码")
ele:adjacentHtml("beforeEnd","代码")
ele:adjacentHtml("afterEnd","代码")
第一个参数表示插入位置,第二个参数表示插入的HTML
ele:adjacentText("beforeBegin","文本")
ele:adjacentText("afterBegin","文本")
ele:adjacentText("beforeEnd","文本")
ele:adjacentText("afterEnd","文本")
第一个参数表示插入位置,第二个参数表示插入的文本
五、模拟点击、自动提交
ele:submit()
模拟提交表单,ele是表单节点或者表单中的一个控件节点。
允许在后台模拟提交(不需要显示web窗体)。
ele:click()
模拟点击HTML节点触发click事件。允许在后台模拟点击(不需要显示web窗体)。

当 ele:click() 函数不起作用怎么办?
通常很少会碰到这个问题,但是在有些情况下ele:click会失效或者被拒绝使用。
这时候可以直接控制鼠标点击节点(web窗体必须是一个前台窗体)。
local x,y,cx,cy = ele:getRect();
mouse.click(x+cx/2,y+cy/2,true);
ele:.getRect()返回的坐标与屏幕的坐标可能有轻微的偏移,如果点击失效请注意一下是否这个原因。
六、执行命令
web.exec(wb,cmd,val);
wb:exec(cmd,val);
在web窗体上执行命令。
ele:exec(cmd,val)
在HTML节点上执行命令。
cmd是一个字符串指令(注意大小写),val是一个可选的附加参数
例如打开另存为对话框
wb:exec("SaveAs","c:\\tttttt.html" )
或者复制一个图像到剪贴板
wb=web.new
("")wb:setTitle
(true);
--打开图片wb:go
("http://www.yhhe.net/bbs/Images/userface/image1.gif");
wb:wait
("")wb:show
();
--取到图片节点ele = wb:eleImages
();
assert(ele:ok
(),
"读取图片节点失败");
--复制图像到剪贴板
ele:exec("Copy");
--从剪贴板获取图片img =image.new
();
img:getClipBD
();
assert( img:ok
(),
"获取图片失败");
--保存图片img:save
( win.saveDlg
("选择文件名",
"*.bmp|*.bmp||") );
然后我们可以轻易的使用img:getClipBD()得到剪贴板上的图像
全部可选命令如下:
2D-Position 允许通过拖曳移动绝对定位的对象。
AbsolutePosition 设定元素的 position 属性为“absolute”(绝对)。
BackColor 设置或获取当前选中区的背景颜色。
BlockDirLTR 目前尚未支持。
BlockDirRTL 目前尚未支持。
Bold 切换当前选中区的粗体显示与否。
BrowseMode 目前尚未支持。
Copy 将当前选中区复制到剪贴板。
CreateBookmark 创建一个书签锚或获取当前选中区或插入点的书签锚的名称。
CreateLink 在当前选中区上插入超级链接,或显示一个对话框允许用户指定要为当前选中区插入的超级链接的 URL。
Cut 将当前选中区复制到剪贴板并删除之。
Delete 删除当前选中区。
DirLTR 目前尚未支持。
DirRTL 目前尚未支持。
EditMode 目前尚未支持。
FontName 设置或获取当前选中区的字体。
FontSize 设置或获取当前选中区的字体大小。
ForeColor 设置或获取当前选中区的前景(文本)颜色。
FormatBlock 设置当前块格式化标签。
Indent 增加选中文本的缩进。
InlineDirLTR 目前尚未支持。
InlineDirRTL 目前尚未支持。
InsertButton 用按钮控件覆盖当前选中区。
InsertFieldset 用方框覆盖当前选中区。
InsertHorizontalRule 用水平线覆盖当前选中区。
InsertIFrame 用内嵌框架覆盖当前选中区。
InsertImage 用图像覆盖当前选中区。
InsertInputButton 用按钮控件覆盖当前选中区。
InsertInputCheckbox 用复选框控件覆盖当前选中区。
InsertInputFileUpload 用文件上载控件覆盖当前选中区。
InsertInputHidden 插入隐藏控件覆盖当前选中区。
InsertInputImage 用图像控件覆盖当前选中区。
InsertInputPassword 用密码控件覆盖当前选中区。
InsertInputRadio 用单选钮控件覆盖当前选中区。
InsertInputReset 用重置控件覆盖当前选中区。
InsertInputSubmit 用提交控件覆盖当前选中区。
InsertInputText 用文本控件覆盖当前选中区。
InsertMarquee 用空字幕覆盖当前选中区。
InsertOrderedList 切换当前选中区是编号列表还是常规格式化块。
InsertParagraph 用换行覆盖当前选中区。
InsertSelectDropdown 用下拉框控件覆盖当前选中区。
InsertSelectListbox 用列表框控件覆盖当前选中区。
InsertTextArea 用多行文本输入控件覆盖当前选中区。
InsertUnorderedList 切换当前选中区是项目符号列表还是常规格式化块。
Italic 切换当前选中区斜体显示与否。
JustifyCenter 将当前选中区在所在格式化块置中。
JustifyFull 目前尚未支持。
JustifyLeft 将当前选中区所在格式化块左对齐。
JustifyNone 目前尚未支持。
JustifyRight 将当前选中区所在格式化块右对齐。
LiveResize 迫使 MSHTML 编辑器在缩放或移动过程中持续更新元素外观,而不是只在移动或缩放完成后更新。
MultipleSelection 允许当用户按住 Shift 或 Ctrl 键时一次选中多于一个站点可选元素。
Open 打开。
Outdent 减少选中区所在格式化块的缩进。
OverWrite 切换文本状态的插入和覆盖。
Paste 用剪贴板内容覆盖当前选中区。
PlayImage 目前尚未支持。
Print 打开打印对话框以便用户可以打印当前页。
Redo 重做。
Refresh 刷新当前文档。
RemoveFormat 从当前选中区中删除格式化标签。
RemoveParaFormat 目前尚未支持。
SaveAs 将当前 Web 页面保存为文件。
SelectAll 选中整个文档。
SizeToControl 目前尚未支持。
SizeToControlHeight 目前尚未支持。
SizeToControlWidth 目前尚未支持。
Stop 停止。
StopImage 目前尚未支持。
StrikeThrough 目前尚未支持。
Subscript 目前尚未支持。
Superscript 目前尚未支持。
UnBookmark 从当前选中区中删除全部书签。
Underline 切换当前选中区的下划线显示与否。
Undo 撤消。
Unlink 从当前选中区中删除全部超级链接。
Unselect 清除当前
七、自动填表
1、input节点、单行文本框设置方法
ele = wb:getEle("节点名e");--参数为input节点的name属性值
ele:setAttribute("value","内容");--通过value属性设置文本框的内容
2、多行文本框设置方法
ele = wb:getEle("节点名");--参数为input节点的name属性值
ele:setTextin("内容");--通过value属性设置文本框的内容
3、下拉列表框设置方法
tele = { ele:childs() };
tele[2]:setAttribute("selected","true");
4、单选控件设置方法
有多个同名的节点将返回一组element对象。
例如:
ele,ele2,ele3 = wb:getEle("option name");
ele2:setAttribute("checked","true");
可以用下面的方法把多个返回值转换为table数组:
eleOptions = { wb:getEle("option name"); }
eleOptions[2]:setAttribute("checked","true")
下面的示例程序通过执行javascript来实现类似的功能:
scr = [[
function selectRadio(name,value)
{
var eleRadios = document.getElementsByName(name);
var i;
var j=0,p=0;
for(i=0;i<eleRadios.length;i++)
{
if(eleRadios[i].value==value)
{
eleRadios[i].checked = true;
j++;
}
}
}
selectRadio("Ans","2");
]]
wb:doScript(scr,"javascript");