CRM开发时常用的js代码

 

Xrm.Page.data.entity.getEntityName();    //获取实体名

Xrm.Page.data.entity.getId();          //获取该条数据的guid(全局唯一标识符)

# 取值:
var oResult = Xrm.Page.getAttribute(sFieldName).getValue();
var oResult = Xrm.Page.getControl(sFieldName).getAttribute().getValue();


# 赋值:
一般类型:Xrm.Page.getAttribute(sFieldName).setValue(object);
OptionSet类型: Xrm.Page.getAttribute(sFieldName).setValue(1);//OptionSet的对应选项的Value
Lookup类型: Xrm.Page.getAttribute(sFieldName).setValue([{ id:"record id", name: "sValue", entityType: "Entity Name" }]);
DateOnly类型: Xrm.Page.getAttribute(sFieldName).setValue(new Date());


# 提示指定错误:
Xrm.Page.getControl(sFieldName).setNotification(sErrorMessage);

# 清除错误提示:
Xrm.Page.getConrol(sFieldName).clearNotification();

# 设置Read Only:
Xrm.Page.getControl(sFieldName).setDisabled(true);

# 设置Enable:
Xrm.Page.getControl(sFieldName).setDisabled(false);

# 控制Tab是否可见:
Xrm.Page.ui.tabs.get("tab_Name").setVisible(true);

# 控制Section是否可见:
Xrm.Page.ui.tabs.get("tab_Name").sections.get("section_name").setVisible(true);

# 设置必填:
Xrm.Page.getAttribute(sFieldName).setRequiredLevel("required");

# 设置可选:
Xrm.Page.getAttribute(sFieldName).setRequiredLevel("none");

# 设置字段可见:
Xrm.Page.getControl(sFieldName).setVisible(true);

# 隐藏字段:
Xrm.Page.getControl(sFieldName).setVisible(false);

# 锁定字段:
Xrm.Page.getControl("sFieldName").setDisabled(true);

# 解锁字段:
Xrm.Page.getControl("addRegions").setDisabled(false);

# 获取当前 Entity Id:
var entityId = Xrm.Page.data.entity.getId();

# 获取当前 Entity 的 Name:
var entityName = Xrm.Page.data.entity.getEntityName();

# 获取当前 User Id:
var userId = Xrm.Page.context.getUserId();

# 判断当前 form 的状态:
if (Xrm.Page.ui.getFormType() == 1){
    //1:Create
}
else{
    //0:Undefined
    //2:Update
    //3:Read Only
    //4:Disabled
    //6:Bulk Edit
}


# 添加事件:
Xrm.Page.getControl(sFieldName).getAttribute().addOnChange(fnOnChange);

# 有時需要獲取當前頁面,所有賦值字段的情況(Debug需要,比如儅出現unsaved changes)
console.log(Xrm.Page.data.entity.getDataXml());

# 查询表的信息
crms_tutor_contract_record contract =service.Retrieve(crms_tutor_contract_record.EntityLogicalName, entity.crms_contract_no.Id, 
new ColumnSet(true)).ToEntity<crms_tutor_contract_record>();

# 在某个日期上加减天数,只要调用Date对象的setDate()函数就可以了,具体方法如下: 
     function addDate(date,days){ 
       var d=new Date(date); 
       d.setDate(d.getDate()+days); 
       var m=d.getMonth()+1; 
       return d.getFullYear()+'-'+m+'-'+d.getDate(); 
     } 
其中,date参数是要进行加减的日期,days参数是要加减的天数,如果往前算就传入负数,往后算就传入正数,如果是要进行月份的加减,
就调用setMonth()和getMonth()就可以了,需要注意的是返回的月份是从0开始计算的,也就是说返回的月份要比实际月份少一个月,因此要相应的加上1。

或者 Convert.ToDateTime(entity.sFieldName).AddDays(day))    //day为具体天数

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值