qooxdoo开发入门

qooxdoo是一个开源的综合性Ajax框架,是遵守LGPL、或EPL(Eclipse Public License)许可的,可以用于商业项目,利于它可以建立面向对象的js类,也可以开发富客户端的界面,甚至在网页上开发出单机程序那样的界面,是一个不错的Ajax框架。

    存在的一个问题是,网络上关于qoodxoo的资料并不多,中文资料更是少之又少,能够看到也就qooxdoo网站上的一些资料,如操作手册( http://qooxdoo.org/documentation/0.8)等。本人经过一些摸索,对于如何搭建qooxdoo的程序有了一些了解,与大家共享。
    从 http://qooxdoo.org/download 下载qooxdoo-0.8.2-sdk,本文的介绍都是针对qooxdoo 0.8.2来说的。对下载后的zip文件解压缩到E:\temp(此处是你自己的解压目录)。下面以$qooxdoo_home$来代替E:\temp\qooxdoo-0.8.2-sdk,即qooxdoo的安装目录。
    此时还不能开始学习qooxdoo,因为qooxdoo是一种编译型的框架,需要用Python来编译js代码,但我们并不需要具有Python的知识。在 http://www.activestate.com/activepython/ 下载ActivePython-2.6.2.2-win32-x86.msi,然后安装。之所以使用ActivePython,是因为它安装后就可以直接用,不需要额外的配置,安装Python 2.x的程序也是可以的。
    在$qooxdoo_home$下面有4个文件夹:
  • application:demo程序。
  • component:框架内部使用的实用程序。
  • framework:框架的源代码和api。
  • tool:框架用于编译的工具,用Python写的,只需要知道怎么使用命令就可以了。
    如果要看到demo程序的效果,需要用generate.py生成一下代码才可以。如我们想看到demobrowser这个demo的效果,需要用以下命令:
    E:\temp\qooxdoo-0.8.2-sdk\application\demobrowser>generate.py source-all
    就会看到在E:\temp\qooxdoo-0.8.2-sdk\application\demobrowser\source下多了一个script文件夹,是由class文件夹下的代码生成的,在程序运行的时候,是执行的script文件夹下的js代码。这样程序就可以运行了。
    在部署程序时,可以使用以下命令生成编译后的代码:
    E:\temp\qooxdoo-0.8.2-sdk\application\demobrowser>generate.py build
    在E:\temp\qooxdoo-0.8.2-sdk\application\demobrowser下就会产生一个build文件夹,里面是经过编译优化后的代码,已经不依赖于qooxdoo框架,因为build时把程序需要的qooxdoo框架中的类编译到目标代码中去了,编译后的js代码体积更小,理论上运行更快。
    如果要建立自己的应用程序,应该如何做呢?有两种方法,下面依次介绍:
    第一种方法:使用 create-application.py生成应用程序骨架,在这个基础上开发自己的程序。这种方法需要使用generate.py编译js代码。
    用以下命令生成代码骨架:
    E:\temp\qooxdoo-0.8.2-sdk\tool\bin> create-application.py --name=demo --out=E:\temp
    其中name是应用程序的名称,out是程序所在的路径。
    但用generate.py生成的代码是把class下的代码都放在一个js文件了,build后会把所有的js类生成在一个js文件中。如果像demobrowser那样把不同的类生成到不同的js中,就需要熟悉config.json的编写方法,用不同的Python任务去产生不同的js文件。
    第二种方法:把qooxdoo源代码编译成一个js文件,嵌入到自己的应用中,就像其他Ajax框架一样。这种方法不需要编译。
    首先要把qooxdoo源代码编译打包成一个文件,使用以下命令:
    E:\temp\qooxdoo-0.8.2-sdk\framework>generate.py build
    在E:\temp\qooxdoo-0.8.2-sdk\framework\build\script下就得到一个qx.js文件,在自己的程序里加入E:\temp\qooxdoo-0.8.2-sdk\framework\build下的内容就可以了。
    使用这种方法开发程序时,与常见的其他Ajax框架就没什么区别了。下面给出一个简单的例子:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<script type="text/javascript" src="js/qx/script/qx.js"></script>
<script type="text/javascript" >
qx.Class.define("demo.Test",
{
extend : qx.application.Inline,
members :
{
main : function()
{
var cmd = document.getElementById("ok");
qx.event.Registration.addListener(cmd, "click", this._clickOk, this);

var cmd2 = new qx.event.Command("Ctrl-L");
cmd2.addListener("execute", function() {
alert("您键入了Ctrl-L");
}, this);

var div1 = new qx.ui.root.Inline(document.getElementById("div1"), false, false).set({backgroundColor:"#FFFFFF"});
var button1 = new qx.ui.form.Button("登录");
div1.add(button1, {left: 100, top: 10});
qx.event.Registration.addListener(button1, "click", this._clickOk, this);
},

_clickOk : function()
{
var userName = document.getElementById("userName").value;
alert("您输入的用户名是:" + userName);
}
}
});

//程序执行的入口类
qx.core.Setting.define("qx.application", "demo.Test");

</script>
</head>
<body>
<center>
用户名:<input type="text" id="userName"/><br>
<input type="button" id="ok" value="确定"/>
</center>
<br/>
<div id="div1" style=""></div>
</body>
</html>
多角色体系 支持管理员、商家、消费者三种角色,权限分级管控: 管理员:负责平台整体配置、用户审核、数据监控等全局操作。 商家:管理店铺信息、发布商品、处理订单、回复评价等。 消费者:浏览商品、加入购物车、下单支付、评价商品等。 实现用户注册(手机号 / 邮箱验证)、登录(支持密码 / 验证码 / 第三方登录)、个人信息管理(头像、收货地址、密码修改)。 权限精细化控制 商家仅能管理自家店铺及商品,消费者仅能查看和购买商品,管理员拥有全平台数据访问权限。 二、商品管理功能 商品信息维护 商家可发布商品:填写名称、分类(如服饰、电子产品)、子类别(如手机、笔记本)、规格(尺寸、颜色、型号)、价格、库存、详情描述(图文)、物流信息(运费、发货地)等。 支持商品上下架、库存调整、信息编辑,系统自动记录商品状态变更日志。 商品分类与搜索 按多级分类展示商品(如 “数码产品→手机→智能手机”),支持自定义分类体系。 提供智能搜索功能:按关键词(名称、品牌)搜索,支持模糊匹配和搜索联想;结合用户浏览历史对搜索结果排序(优先展示高相关度商品)。 商品推荐 基于用户浏览、收藏、购买记录,推荐相似商品(如 “浏览过该商品的用户还买了…”)。 首页展示热门商品(销量 TOP10)、新品上架、限时折扣等推荐列表。 三、订单与交易管理 购物车与下单 消费者可将商品加入购物车,支持修改数量、选择规格、移除商品,系统自动计算总价(含运费、折扣)。 下单流程:确认收货地址→选择支付方式(在线支付、货到付款)→提交订单→系统生成唯一订单号。 订单处理流程 订单状态跟踪:待支付→已支付→商家发货→物流运输→消费者收货→订单完成,各状态变更实时通知用户。 商家端功能:查看新订单提醒、确认发货(填写物流单号)、处理退款申请(需审核理由)。 消费者端功能:查看订单详情、追踪物流、申请退款 / 退货、确认收货。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值