Introduction
PreSaveAction() is a JavaScript function that helps us to do something before the item will be saved. PreSaveAction function allows overriding functionality when the Save button is clicked. PreSaveAction function executes the code written for validation on the click of the save button. I just want to add one thing, you should override PreSaveItem - this is a SharePoint built in function. Instead, like mentioned above - override/create PreSaveAction.
Scenario
I have a default SharePoint list form with saving or cancel, I want the user to attach files while creating a new item. When the user clicks on save button, page post back happens and if validation fails, the validation message is displayed.
Solution
I used the following code with PreSaveAction function for validation to display messages on Save button click and Save button, attach runtime custom handler. Default Save button calls PreSaveItem method, which in turn calls PreSaveAction for any validations.
- $(document).ready(function ()
- {
- ProducerReferral();
- attachEventHandlers(); // function for checking the duplication of files
- $('input[value=Save]').click(function ()
- {
- PreSaveTest();
- });
- });
- function PreSaveTest()
- {
- PreSaveAction();
- }
- function PreSaveAction()
- {
- if ($("#idAttachmentsRow").css("display") == "none")
- {
- $("#part1 > h4")[1].innerHTML += "<span style='margin-left: 40px;' class='ms-formvalidation ms-csrformvalidation'>Please Attach Files.</span>";
- returnVal = false;
- }
- else
- {
- return true;
- }
- }
Note: If you are using "$(document).ready" in your code, make sure PreSaveAction function is written outside this block, as in above code or else PreSaveAction method will not be called.
Reference
No comments:
Post a Comment