• firefox扩展开发(二):用XUL创建窗口控件


    firefox扩展开发(二):用XUL创建窗口控件
    2008-06-11 16:57

    1.创建一个简单的窗口

    1. <?xml version="1.0"?>
    2. <?xml-stylesheet href="chrome://global/skin/" type="text/css"?>
    3. <window
    4. id="test-window"
    5. title="测试用的窗口"
    6. xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
    7.  
    8. </window>

    把上述的代码保存为test.xul,然后在firefox的“文件” --> “打开文件” 中打开这个文件,就可以看到(下图)。

    哎,怎么啥都没有? 因为我们还没有往窗口中加入任何东西,所以除了标题栏之外,是一片空白。实际上,上面的XUL文件,是每个窗口的基本框架。

    第1行是XML文件的基本表示,第2行引用渲染窗口控件的样式表文件,这里我们先跳过对这行的解释,只要知道“chrome://global/skin/” 引用的是firefox全局默认的样式表即可。

    第3行的<window>元素,就是窗口的根元素,你可以把它想象成HTML中的<html>元素。属性id的值可以随便 取,和HTML中的id属性相同,必须要保证全局唯一,因为之后我们要通过id来引用每个窗口。title属性就是窗口的标题,xmlns是名称空间,说 明之下的内容是XUL。

    窗口中所有的内容,都要放在<window>和</window>之间,就像HTML中所有的元素必须放在<html>和</html>之间一样。

    2.让我们往窗口里添点东西吧

    所有一般程序具有的窗口控件(按钮、单选复选框、文本输入框、下拉菜单……),在firefox的窗口中都可以实现,只不过,不同的窗口控件在XUL中变成了不同的XML标签,控件的属性(大小、文本、排列方式……)变成了标签的属性值而已。

    2.1按钮

    我们先来添加个按钮,打开test.xul,添加下面的代码:

    1. <?xml version="1.0"?>
    2. <?xml-stylesheet href="chrome://global/skin/" type="text/css"?>
    3. <window
    4. id="test-window"
    5. title="测试用的窗口"
    6. xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
    7.  
    8. <button label="普通的按钮"/>
    9.  
    10. </window>

    按钮在XUL中就是<button>这个标签,label属性为按钮上显示的文字。

    2.2文字

    在窗口上显示的文字,用<label>标签来显示:

    1. <?xml version="1.0"?>
    2. <?xml-stylesheet href="chrome://global/skin/" type="text/css"?>
    3. <window
    4. id="test-window"
    5. title="测试用的窗口"
    6. xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
    7.  
    8. <label value="下面是一个普通的按钮:)"/>
    9. <button label="普通的按钮"/>
    10.  
    11. </window>

    2.3文本输入框

    文本输入框,为<textbox>标签。让我们清除刚才添加的代码,下面的代码显示了<textbox>的几种用法。

    1. <?xml version="1.0"?>
    2. <?xml-stylesheet href="chrome://global/skin/" type="text/css"?>
    3. <window
    4. id="test-window"
    5. title="测试用的窗口"
    6. xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
    7.  
    8. <label value="用户名"/>
    9. <textbox id="username"/>
    10. <label value="密码"/>
    11. <textbox id="password" type="password" maxlength="10"/>
    12.  
    13. <label value="个人简介"/>
    14. <textbox multiline="true"
    15.    value="在这里填入你的个人简介。"/>
    16.  
    17. </window>

    第11行,密码输入框要设置type属性为"password";第14行,如果需要多行的输入框,需要指定multiline为"true"。

    转自:http://www.cnblogs.com/jxsoft/archive/2011/04/07/2008179.html
  • 相关阅读:
    Java
    oracle与mysql(2)
    oracle与mysql
    junit中的assert方法总结
    java Future用法和意义一句话击破
    Java序列化中的SerialVersionUid
    Nginx了解
    现如今的CDN网站加速技术,细说CDN
    slf4j日志的使用
    IDEA 快捷键整理
  • 原文地址:https://www.cnblogs.com/lvchenfeng/p/5081116.html
Copyright © 2020-2023  润新知