Javascript实例教程(19) 使用HoTMetal(4)


Posted in Javascript onDecember 23, 2006
HoTMetal中使用javascript

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的对话框:

Javascript实例教程(19) 使用HoTMetal(4)

(图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所示:

Javascript实例教程(19) 使用HoTMetal(4)

(图2)

现在我们选择三行,这三行包括了以"does not specify:"开头的行,如图3所示:

Javascript实例教程(19) 使用HoTMetal(4)

(图3)

最后我们点击中在窗口左上角上的绿色箭头,接着宏的名字(Format Current Selection)就显示在下拉菜单的窗口中,如图4所示:

Javascript实例教程(19) 使用HoTMetal(4)

(图4)

值得一提的是,被选择的行已经被格式化为原来的段落边界。以"referred to in this ma"为开头的第二行保持缩进状态而没有被格式化。

Javascript 相关文章推荐
js内置对象 学习笔记
Aug 01 Javascript
js带按钮的提示框可供选择示例代码
Sep 17 Javascript
JS获取月的最后一天与JS得到一个月份最大天数的实例代码
Dec 16 Javascript
jquery 获取 outerHtml 包含当前节点本身的代码
Oct 30 Javascript
JavaScript 学习笔记之数据类型
Jan 14 Javascript
JS中多步骤多分步的StepJump组件实例详解
Apr 01 Javascript
个人网站留言页面(前端jQuery编写、后台php读写MySQL)
May 03 Javascript
bootstrap table操作技巧分享
Feb 15 Javascript
vue 实现数字滚动增加效果的实例代码
Jul 06 Javascript
JavaScript时间日期操作实例小结【5个示例】
Dec 22 Javascript
js实现选项卡效果
Mar 07 Javascript
vue项目中使用bpmn为节点添加颜色的方法
Apr 30 Javascript
Javascript实例教程(19) 使用HoTMetal(3)
Dec 23 #Javascript
Javascript实例教程(19) 使用HoTMetal(2)
Dec 23 #Javascript
Javascript实例教程(19) 使用HoTMetal(1)
Dec 23 #Javascript
用于自动添加Digg This!按钮的JavaScript
Dec 23 #Javascript
获取任意Html元素与body之间的偏移距离 offsetTop、offsetLeft (For:IE5+ FF1 )[
Dec 22 #Javascript
获取Javscript执行函数名称的方法
Dec 22 #Javascript
在Javascript中定义对象类别
Dec 22 #Javascript
You might like
php全角字符转换为半角函数
2014/02/07 PHP
php封装单文件上传到数据库(路径)
2017/10/15 PHP
PHP+Ajax实现的检测用户名功能简单示例
2019/02/12 PHP
关于PHP求解三数之和问题详析
2020/11/09 PHP
javascript firefox兼容ie的dom方法脚本
2008/05/18 Javascript
javascript 最常用的10个自定义函数[推荐]
2009/12/26 Javascript
Firefox中beforeunload事件的实现缺陷浅析
2012/05/03 Javascript
JQuery判断radio是否选中并获取选中值的示例代码
2014/10/17 Javascript
ECMAScript 5严格模式(Strict Mode)介绍
2015/03/02 Javascript
javascript实现类似百度分享功能的方法
2015/07/27 Javascript
JS字符串的切分用法实例
2016/02/22 Javascript
Bootstrap学习笔记之css样式设计(2)
2016/06/07 Javascript
js 实现数值的千分位及保存小数方法(推荐)
2016/08/01 Javascript
chrome下判断点击input上标签还是其余标签的实现方法
2016/09/18 Javascript
WEB开发之注册页面验证码倒计时代码的实现
2016/12/15 Javascript
JS库之Highlight.js的用法详解
2017/09/13 Javascript
详解Chart.js轻量级图表库的使用经验
2018/05/22 Javascript
微信小程序实现自定义picker选择器弹窗内容
2020/05/26 Javascript
layui前端框架之table表数据的刷新方法
2018/08/17 Javascript
微信小程序实现登录遮罩效果
2018/11/01 Javascript
基于vue+axios+lrz.js微信端图片压缩上传方法
2019/06/25 Javascript
jquery实现垂直手风琴导航栏
2020/02/18 jQuery
vue实现简易计算器功能
2021/01/20 Vue.js
django 常用orm操作详解
2017/09/13 Python
详解Python对JSON中的特殊类型进行Encoder
2019/07/15 Python
Python3将jpg转为pdf文件的方法示例
2019/12/13 Python
tensorflow pb to tflite 精度下降详解
2020/05/25 Python
创先争优活动承诺书
2014/08/30 职场文书
2014基层党员批评与自我批评范文
2014/09/24 职场文书
党员检讨书
2014/10/13 职场文书
出差报告范文
2014/11/06 职场文书
2014年圣诞节寄语
2014/12/08 职场文书
2014年生产部工作总结
2014/12/17 职场文书
考试作弊检讨书怎么写?
2014/12/21 职场文书
2015个人简历自我评价语
2015/03/11 职场文书
Python+Appium实现自动抢微信红包
2021/05/21 Python