Wednesday, 25 January 2012

Creating a List Item Using ECMAScript (JavaScript, JScript)


<table width="364" height="83" border="1">
  <tr>
    <td>Enter the Title:</td>
    <td><input type="text" id="titletxt" name="titletxt"> </td>
  </tr>
  <tr>
    <td>Enter the Name:</td>
    <td><input type="text" id="nametxt" name="nametxt"> </td>
  </tr>
  <tr>
    <td colspan="2"><input id="btnGetFieldType" onclick="getFieldType()" type="button" value="Get Field Type" align="middle" /></td>
   
  </tr>
</table>
<script language="ecmascript" type="text/ecmascript">
        var fieldCollection;
        var field;
        var list;
var t=document.getElementById('titletxt');
var n=document.getElementById('nametxt');
        function getFieldType() {
            var clientContext = SP.ClientContext.get_current();
            if (clientContext != undefined && clientContext != null) {
                var oList = clientContext.get_web().get_lists().getByTitle('ecmascript List');
       
    var itemCreateInfo = new SP.ListItemCreationInformation();
    this.oListItem = oList.addItem(itemCreateInfo);
       
    oListItem.set_item('Title',t.value);
    oListItem.set_item('Name',n.value);
       
    oListItem.update();

     clientContext.load(oListItem);
 clientContext.executeQueryAsync(Function.createDelegate(this, this.onQuerySucceeded), Function.createDelegate(this, this.onQueryFailed));
            }
        }
      function onQuerySucceeded() {

    alert('Item created: ' + oListItem.get_id());
}

function onQueryFailed(sender, args) {

    alert('Request failed. ' + args.get_message() + '\n' + args.get_stackTrace());
}</script>

Tuesday, 24 January 2012

Set The Default Value For The Field in SharePoint 2010 Using ECMAScript


Introduction

In this article you will see how to set the default value for the field in SharePoint 2010 using ECMAScript. I have a list named "List Request" which has the following fields (Navigate to the list, click on List tab in the ribbon interface. Click on List Settings button).

Script1.gif

I am going to set the default value for the column named "Description" using ECMAScript.

Steps Involved

Step 1 : Navigate to the SharePoint site (I have a site page created in my site where I am going to add the content editor web part).

Step 2 : Go to Site Actions, click on Edit Page.

SharePoint2.gif

Step 3 : Click on the Insert tab in the ribbon interface and then click on Web Part button.

SharePoint3.gif

Step 4 : Select Media and Content in the Categories section and then click on Content Editor.

SharePoint4.gif

Step 5 : Click on Add.

Step 6 : The Content Editor web part will be added to the site page.

Step 7 : Click on the down arrow and then click on Edit Web Part.

SharePoint5.gif

Step 8 : Click on "Click here to add new content".

SharePoint6.gif

Step 9 : Click on Format Text tab in the ribbon interface and then click on HTML drop down.

SharePoint7.gif

Step 10 : Click on Edit HTML source.

Step 11 : The HTML source window will pop up.

SharePoint8.gif

Step 12 : Copy and paste the following script.
<script language="ecmascript" type="text/ecmascript">
        var fieldCollection;
        var field;
        var list;
        function fieldDefaultValue() {
            var clientContext = SP.ClientContext.get_current();
            if (clientContext != undefined && clientContext != null) {
                var webSite = clientContext.get_web();
                this.list = webSite.get_lists().getByTitle("List Request");
                this.fieldCollection = list.get_fields();
                this.field = fieldCollection.getByTitle("Description");
                this
.field.set_defaultValue("Default");                this.field.update();                clientContext.load(this.field);
                clientContext.executeQueryAsync(Function.createDelegate(thisthis.OnLoadSuccess),
Function.createDelegate(thisthis.OnLoadFailed));
            }
        }
        function OnLoadSuccess(sender, args) {
            
alert(this.field.get_defaultValue());        }
        function OnLoadFailed(sender, args) {
            alert('Request failed. ' + args.get_message() + '\n' + args.get_stackTrace());
        }
</
script
>    <input id="btnFieldDefaultValue" onclick="fieldDefaultValue()" type="button" value="Field Default Value" />

Step 13 : Click on Ok.

Step 14 : In the ribbon interface click on the Save & Close button.

SharePoint9.gif

Step 15 : In the content editor web part you can find a button named "Field Default Value"; click on that button.

SharePoint10.gif

Step 16 : An alert will pop up which displays the default value for the field.

Script2.gif