- 热门文章:
- · Javascript实例教程(19) 使用HoTMetal(3)
- · Javascript实例教程(19) 使用HoTMetal(2)
- · Javascript实例教程(19) 使用HoTMetal(1)
- · Javascript实例教程(18) 数组
- · Javascript实例教程(14) JS代替CGI
- · Javascript实例教程(13) 鼠标触发窗口
- · Javascript实例教程(12) 鼠标移过时报警
- · Javascript实例教程(11) 隐藏script代码
- · Javascript实例教程(10) 创建"后退"按钮
- · Javascript实例教程(9) 随机显示图片
- · Javascript实例教程(8) 检验表单有效性
- · Javascript实例教程(7) 利用Javascript基于浏览器类型的重定向
Javascript实例教程(19) 使用HoTMetal(4)
4. 怎样编写文档格式的脚本
下面举个宏的例子:根据预定义的页面的布置准则来格式化文档。为了观察这个宏的效应,请关闭Enable Source Layout(允许源程序布局)按钮,具体从菜单中选择Tools(工具)->Customization(定制)。我们首先打开应用程序来初始化一些全局的变量。另外宏的名字必须为n_Application_Open,具体的代码如下:
<MACRO name="On_Application_Open" lang="JScript"><![CDATA[
var viewWYSIWYG = 0;
var viewTagsOn = 1;
var viewSource = 2;
]]></MACRO>
这个宏必须在打开HoTMetaL应用程序的时候才被调用。它唯一的目的就是定义三个常数,这些常数用于其它的宏。这些常数只是代表了三个相应的HoTMetaL视图。操作HoTMetaL的编辑窗口的左边按钮边角上的窗口标签,你可以看到WYSIWYG(即所见即所得)视图,TagsOn视图和源程序视图。
下面得宏是检查当前视图是否是源视图并且根据预定义的准则格式化整个文档。如果视觉图不是源视图,一个消息就会打印出来显示给用户,并且告诉用户切换视图,代码如下:
<MACRO name="Format Current Document" lang="JScript" id="153" desc="Apply source layout to entire document">
<![CDATA[
if (ActiveDocument.ViewType == viewSource) {
ActiveDocument.Layout();
}
else {
Application.Alert("Applying source layout only works in source view.\nSwitch to source view and try again.");
}
]]></MACRO>
这里要注意,我们在这里已经使用了两个HotMetaL的对象:ActiveDocument 和 Application。这个Layout()方法格式化了当前文档。而Alert()方法弹出了一个警告方框。
好吧,现在让我们来测试一下这个宏。请在HotTMetaL中打开一个文档并将视图切换到源程序视图。你可以在ProgGuide目录中选择其中一段。并且通过使用Tools(工具)->Customization(定制)关闭Enable Source Layout按钮。接着将其中一行用加入空格往右移,再从工具菜单中调用宏对话框。这时会展现出定义在HotMetaL.mcr文件的宏的列表。然后运行Refresh Macros宏来装载你刚才编辑的新的宏。你将会看到Format Current Document (格式当前文档)宏。你可以运行它并且注意那个缩进的行回到它的原位置。接下来我们测试一下Alert()方法。现在将视图切换到TagsOn视图并再次运行宏,会弹出如图1的对话框:
(图1)
现在假设你想格式化文档中所选择的部分。这个请求的宏(称为Format Current Selection)跟上面所述的宏(Format Current Document)很类似。它们之间的不同只是在:Format Current Document中 Layout()方法是操作ActiveDocument 对象,而Format Current Selection中 Layout()方法是操作Selection对象:
<MACRO name="Format Current Selection" lang="JScript" id="53" desc="Apply source layout to the current selection">
<![CDATA[
if (ActiveDocument.ViewType == viewSource) {
Selection.Layout();
} else{
Application.Alert("Applying source layout only works in source view.\nSwitch to source view and try again.");
}
]]></MACRO>
下面让我们好好看看上面这个宏是如何工作的。我们在打开的文档中缩进了两行。第一行是以”does not specify”开头的,而另外一句是以"referred to in this ma:"开头的。如图2所示:
(图2)
现在我们选择三行,这三行包括了以"does not specify:"开头的行,如图3所示:
(图3)
最后我们点击中在窗口左上角上的绿色箭头,接着宏的名字(Format Current Selection)就显示在下拉菜单的窗口中,如图4所示:
(图4)
值得一提的是,被选择的行已经被格式化为原来的段落边界。以"referred to in this ma"为开头的第二行保持缩进状态而没有被格式化。
相关文章:
- · Javascript实例教程(6) 利用Javascript进行密码保护
- · Javascript实例教程(5) 在一个表单中设置和检查Cookies
- · Javascript实例教程(3) 探测浏览器插件
- · Javascript实例教程(2) 创建折叠式导航菜单
- · Javascript实例教程(1) 创建弹出式窗口
- · JS实现身份证号码15位转18位时最后一位的算法
- · 如何用Javascript获得TextArea中的光标位置
- · 张孝祥JavaScript教程笔记:HTML基础(三)-URL,图像标签,图像地图
- · 限制图片上传长宽的JavaScript代码
- · 判断输入框中的小数点问题
- · 判断输入框中的小数点问题
- · 实用函数:判断输入的是否是电话号码
- · 网页之定时器详解
- · 张孝祥JavaScript教程笔记:HTML基础(二)
- · 用网页代码实现把TAB键变为Enter键
- · 张孝祥JavaScript教程笔记:HTML基础
- · Javascript控制XSlt转换XML
- · 弹出新窗口,填写数据,提交后,关闭该弹出窗口,刷新父页面
- · 无限分类算法 js 的实现
- · 怎么强制弹出窗口永远在最前面
- · 如何控制框架页的滚动
- · 在单元格里或层里出现滚动条
- · 实现页面打开后滚动到最底端的效果
- · Step By Step 制作XML的Javascript树形目录
- · 怎样屏蔽浏览器关闭按钮及ALT+F4 快捷键
- · 判断checkbox是否至少有选择一项
- · 全新的音乐防盗连技术
- · 解决未知尺寸的图片撑破页面的问题
- · 比较实用的首页调用文章的两个函数
- · 一个解析URL及图片地址的JS函数
- · 让处于contentEditable=true的层里面的图片响应键盘事件
- · 单击图片时直接出现另存为对话框
- · 单击图片时直接出现另存为对话框
- · JS控制INPUT格式时间输入
- · Javascript实现图片按比例缩放的函数
- · 网页中图片和文字相分离的方法
- · 用Javascript模仿DataGrid
- · JavaScript写自定义对象语法
