设为首页 收藏本站
查看: 965|回复: 0

[经验分享] Sharepoint ECMAScript

[复制链接]

尚未签到

发表于 2015-9-28 12:32:42 | 显示全部楼层 |阅读模式
前言
  本文完全原创,转载请说明出处,希望对大家有用。
  本篇博客是个人总结,一方面以便日后查看,另一方面希望能为其他人提供一些便利。



阅读目录


  • 加载必要文件
  • (Get,Update,Delete,Add) ListItem
  • 使用SPQuery



正文


加载必要文件

在使用SharePoint ECMAScript之前,我们需要引入几个JS文件:


  •   SP.js

  •   SP.Core.js

  •   SP.Runtime.js



  SP.js:包含主要的能够用来获取sharepoint数据的对象,如ClientContext、Web、List、Listitem等
  SP.Core.js:包含一些实用对象和帮助对象,能够用来完成基本的任务,如HTML编码、URL处理、XML字符串操作等
  SP.Runtime.js:包含了核心的ECMAScript运行时的对象,封装了客户端对象模型和服务器进行交互处理的所有细节
  SP.UI.<**>.js:一系列以SP.UI打头的文件提供了UI处理方面的扩展功能,例如SP.UI.Dialog.js包含了对Dialog Framework的支持
  SP.Ribbon.js:包含了对Ribbon开发的支持
  如果此时使用的是系统默认母板页,就不需要再次引用这些文件。如果使用的是自定义母板页,需要引入这些文件,或者在母板页里引用。
  SharePoint提供了js的Debug版本,便于开发,但正式环境需要引用非Debug版本。
  另外,如果有修改SharePoint Content Database数据库的代码,需要加入FormDigest:



<asp:Content ID="PageHead" ContentPlaceHolderID="PlaceHolderAdditionalPageHead" runat="server">
<script type="text/javascript" src="_Layouts/sp.runtime.js"></script>
<script type="text/javascript" src="_Layouts/sp.js"></script>
<script type="text/javascript">
$(document).ready(function () {
ExecuteOrDelayUntilScriptLoaded(function () {
var clientContext;
var listCreationInfo;
var web;
var list;
clientContext = SP.ClientContext.get_current();
web = clientContext.get_web();
list = web.get_lists().getByTitle('CustomList');
clientContext.load(list);
clientContext.executeQueryAsync(function () { alert("Success!") }, function () { alert("Request failed") });
}, "sp.js");
});
</script>
</asp:Content>
<asp:Content ID="Main" ContentPlaceHolderID="PlaceHolderMain" runat="server">
<SharePoint:FormDigest ID="FormDigest1" runat="server"></SharePoint:FormDigest>
</asp:Content>
  


Manage ListItem
  GetItemByItemID



       function (itemid) {
var clientContext;
var listCreationInfo;
var web;
var list;
clientContext = SP.ClientContext.get_current();
web = clientContext.get_web();
list = web.get_lists().getByTitle('CustomList');;
This.item = list.getItemById(itemId);
clientContext.load(list);
clientContext.executeQueryAsync(function () { alert("Success!") }, function () { alert("Request failed") });
}
  Add a new item to list



                clientContext = SP.ClientContext.get_current();
web = clientContext.get_web();
list = web.get_lists().getByTitle('CustomList');
var listItemInfo = new SP.ListItemCreationInformation();
// add the item to the list
var listItem = list.addItem(listItemInfo);
listItem.set_item('Title', "Success");
This.item = list.getItemById(itemId);
var LookupTestValue = new SP.FieldLookupValue();
LookupTestValue.set_lookupId(employeeId);
listItem.set_item('LookupTest', LookupTestValue);
listItem.update();
clientContext.executeQueryAsync(function () { alert("Success!") }, function () { alert("Request failed") });
  Delete a item from list



            function deleteItem(itemId) {
var clientContext = new SP.ClientContext.get_current();
var web = context.get_web();
var list = web.get_lists().getByTitle('CustomList');
var item = list.getItemById(itemId);
item.deleteObject();
clientContext.executeQueryAsync(function () { alert("Success!") }, function () { alert("Request failed") });
}

使用SPQuery



            function get_itemByQuery(title) {
try {
var clientContext = new SP.ClientContext.get_current();
this.web = context.get_web();
var list = this.web.get_lists().getByTitle('CustomList');
var query = '<View Scope=\'RecursiveAll\'>' +
'<Query>' +
'<Where>' +
'<Eq>' +
'<FieldRef Name=\'Title\' />' +
'<Value Type=\'LookUp\'>' + title + '</Value>' +
'</Eq>' +
'</Where>' +
'</Query>' +
'</View>';
var camlQuery = new SP.CamlQuery();
camlQuery.set_viewXml(query);
this.Queryitems = list.getItems(camlQuery);
clientContext.load(this.Queryitems);
clientContext.executeQueryAsync(function () { alert("Success!") }, function () { alert("Request failed") });
}
catch (e) {
alert("error occurred" + e.toString());
}
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-119990-1-1.html 上篇帖子: 在IE11下设置SharePoint Server 2013却遇到“需要 Internet Explorer 才能使用此功能。”的解决办法 下篇帖子: 好像越来越觉得 SharePoint “难用”了
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表