UAP 从前端到后端 详细教程 (四) WebLet里的代码

DetailView.js

$ns("holiday.views");

$import("mx.controls.ToolBar");
$import("mx.datacontrols.DataForm");

holiday.views.DetailView = function() {
	var me = $extend(mx.views.View);
	var base = {};

	me.objID = null;

	me.form = null;

	base.init = me.init;
	me.init = function() {
		base.init();

		_initControls();
	};
	
	function _initControls() {
		// 表单的 工具栏 ,我只添加了一条 保存的工具
		var toolBar = new mx.controls.ToolBar({
			width : "100%",
			items : [ {
				name : "save",
				text : mx.msg("SAVE"),
				imageKey : "save",
				toolTip : mx.msg("SAVE"),
				// _btnSave_onclick 这个方法 DetailViewController 要有
				// 具体实现自己 编写
				onclick : me.controller._btnSave_onclick
			} ]
		});
		
		me.addControl(toolBar);
		/** 获取下面字段的 值传给后台 */
		//var all_data = me.view.form.entityContainer.data;
		//console.log(me.view.form.entityContainer.dicts);
		var deFormEntity = new mx.datacontainers.FormEntityContainer({
			baseUrl : holiday.mappath("~/rest/holiday/info"),
			primaryKey : "ID",
			// 根据 FieldsName,自动赋值到本地
			// 从后端,加载 表单的数据
			type: "remote",
			// 表示当前数据容器是否有元数据信息
			// true 的话,弹出此表单会 额外发送一条 url 请求
			loadMeta:false
		})
		me.form = new mx.datacontrols.DataForm({
			entityContainer : deFormEntity,
			// TODO 指定主键列名
			// TODO 指定显示列数组
			fields : [ {
				name : "ID",
				caption : "编号",
				editorType : "NumberEditor",
				colSpan: "2",
				readOnly : false
			},{
				name : "USERID",
				caption : "请求人编号",
				colSpan: "2",
				editorType : "NumberEditor",
				readOnly : false
			},{
				name : "REQUEST_DATE",
				caption : "请假发起日期",
				editorType : "DateTimeEditor",
				colSpan: "2",
				readOnly : false
			},{
				name : "REQUEST_REASON",
				caption : "请假原因",
				editorType : "TextEditor",
				colSpan: "5",
				readOnly : false
			},{
				name : "REQUEST_DAYS",
				caption : "请假天数",
				editorType : "NumberEditor",
				colSpan: "2",
				readOnly : false
			},{
				name : "APPROVER_UID",
				caption : "审批人编号",
				colSpan: "2",
				editorType : "NumberEditor",
				readOnly : false
			},{
				name : "STATE",
				caption : "状态",
				colSpan: "2",
				// 下拉选的类型
				editorType : "DropDownEditor",
				allowEditing: false, 
				// 指定显示的 是 name
				displayMember: "name",
				// 指定实际值 是 name
				valueMember: "name",
				// 下拉选里面的元素
				items: [ { name: "待批准" }, { name:"已批准"},{ name: "不批准"}] ,
				readOnly : false
			} ]
		});

		me.addControl(me.form);

		me.on("activate", me.controller._onactivate);
	}

	return me.endOfClass(arguments);
};

DetailViewController.js

$ns("holiday.views");
$import("holiday.views.DetailView");

holiday.views.DetailViewController = function(selectValues) {
	var me = $extend(mx.views.ViewController);
	var base = {};

	me.getView = function() {
		if (me.view == null) {
			me.view = new holiday.views.DetailView({
				controller : me
			});
		}
		return me.view;
	};

	me._onactivate = function(e) {
		// TODO: 窗体激活时的逻辑。
		if (me.view != null && typeof (me.view.form) != "undefined") {
			me.view.form.load(me.view.objID);
		}
	};
	// 创建 一个RESTClient,利用这个 向后台发送请求 (这个就是框架封装的 Ajax)
	var client_edit = new mx.rpc.RESTClient({
		baseUrl : holiday.mappath("~/rest/holiday")
	});
	// 回掉函数
	var call_backFun =  function(obj) {
		if (obj.successful) {
			mx.indicate("info", "修改成功");
			// dataGrid.load();
		} else {
			mx.indicate("info", "sorry,修改失败");
		}
	}

	/** 编辑时点击保存的逻辑 */
	me._btnSave_onclick = function() {
		var all_data = me.view.form.entityContainer.data;
		// me.view.form.save();
		// 这里 给  view的objID 赋值,是因为向后台发送请求时,会把 这个 objID 拼上去
		// 这个 view 其实 就是 DetailView me就是 DetailViewController 对象
		// me 也就是本身
		if (me.view.objID == 'new') {
			client_edit.get("/new",all_data,call_backFun);
		} else {
			client_edit.get("/saveEdit", all_data,call_backFun);
		}
		console.log("保存-调用over!");

		// 重新加载数据,不然修改完 需要手动刷新页面 才看得到效果
		// me.view.form.load();
	};

	return me.endOfClass(arguments);
};

然后贴两张 表单弹出的视图.

新建和 编辑 弹出的是同一个表单,但是传递的参数不同

所以,执行的 功能有点不同.

 

  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值