As a ShaePoint developer, most of us have worked on customizing New or Edit form using JavaScript which works but it's a workaround, not an elegant solution. But with JSLink, we don't have to add Content Editor web part to OOTB NewForm.aspx or EditForm.aspx, instead we just have edit the page and set JSLink property.
In this post I am using the same Tasks list as in previous post and will enhance the new and edit forms, by replacing "% Complete" input control with dropdown list with predefined values. Here is the final result:
To achieve this result, create JavaScript file and copy/paste following code snippets. See comments for explanation:
// JavaScript source code
(function () {
var overrideCtx = {};
overrideCtx.Templates = {};
//override 'PercentComplete' field and provide custom rendering functions
//for NewForm.aspx and EditForm.aspx pages.
overrideCtx.Templates.Fields = {
'PercentComplete': { 'NewForm': customField, 'EditForm': customField }
}
//register our override
SPClientTemplates.TemplateManager.RegisterTemplateOverrides(overrideCtx);
})();
function customField(ctx) {
//get form context for our field
var formCtx = SPClientTemplates.Utility.GetFormContextForCurrentField(ctx);
//local vars:
var fldName = "cbo_" + formCtx.fieldName; //used to set id of dropdown
var fldValue = parseInt(formCtx.fieldValue); //get current value for edit form
//register value callback. this function is called before submitting form
//returned value will be saved in PercentComplete field. make sure the
//return type is compatible with field data type.
formCtx.registerGetValueCallback(formCtx.fieldName, function () {
var cbo = document.getElementById(fldName);
return cbo.options[cbo.selectedIndex].value;
});
//return <select> html to replace input control
var html = [];
html.push("<select id='" + fldName + "'>");</select>
html.push(getSelectItem(0, fldValue));
html.push(getSelectItem(25, fldValue));
html.push(getSelectItem(50, fldValue));
html.push(getSelectItem(75, fldValue));
html.push(getSelectItem(100, fldValue));
return html.join('');
}
//build <option> tag
function getSelectItem(value, selValue) {
if (value === selValue)
return "<option selected='selected' value='" + value + "'>" + value + "'</option>";
return "<option value='" + value + "'>" + value + "</option>";
}
Upload JS file to Master Page library and set metadata as below:
Content Type | JavaScript Display Template |
Target Control Type | Form |
Standalone | Override |
Target Scope | Server relative URL of site |
Target List Template Id | List template Id (optional) |
At this point only task remaining is to edit "NewForm.aspx" / "EditForm.aspx" pages and set JSLink proerty of "ListFormWebPart". You can do this through UI (edit page), Feature receiver or PowerShell script.
Go back to Tasks list and add or edit item to see customization. In next post, will see how we can add custom field validation.
Go back to Tasks list and add or edit item to see customization. In next post, will see how we can add custom field validation.
Hope this help.
-Javed
Thank you very much!
ReplyDeletePerhaps this line:html.push("select id='" + fldName + "'>");</select>
</select> is shouldn't be here,I think.
Add this code :html.push("</select>") at back may be better.
Bermuda yurtdışı kargo
ReplyDeleteBonaire yurtdışı kargo
Bolivya yurtdışı kargo
Birleşik Arap Emirlikleri yurtdışı kargo
Bhutanya yurtdışı kargo
R6PL
sakarya
ReplyDeletedüzce
çankırı
sivas
elazığ
J2KBXV
maraş evden eve nakliyat
ReplyDeletemaraş evden eve nakliyat
izmir evden eve nakliyat
konya evden eve nakliyat
erzurum evden eve nakliyat
F5O1
urfa evden eve nakliyat
ReplyDeletemalatya evden eve nakliyat
burdur evden eve nakliyat
kırıkkale evden eve nakliyat
kars evden eve nakliyat
FOXLW
4DFA9
ReplyDeleteSinop Parça Eşya Taşıma
Yozgat Evden Eve Nakliyat
Bilecik Lojistik
Amasya Lojistik
Çorum Evden Eve Nakliyat
5B5C8
ReplyDeleteBolu Şehir İçi Nakliyat
Kayseri Şehir İçi Nakliyat
Giresun Lojistik
Bilecik Şehir İçi Nakliyat
Sakarya Evden Eve Nakliyat
Kırşehir Parça Eşya Taşıma
Siirt Evden Eve Nakliyat
Çorum Şehirler Arası Nakliyat
Adıyaman Evden Eve Nakliyat
C8C62
ReplyDeleteOsmaniye Şehir İçi Nakliyat
Balıkesir Şehirler Arası Nakliyat
backlink
Gölbaşı Boya Ustası
Sakarya Şehirler Arası Nakliyat
vezir sosyal medya
buy pharmacy steroids
Diyarbakır Lojistik
Niğde Şehir İçi Nakliyat
BA490
ReplyDeleteKarabük Parça Eşya Taşıma
Btcturk Güvenilir mi
Ünye Parke Ustası
Çerkezköy Yol Yardım
Tokat Evden Eve Nakliyat
Konya Lojistik
Tokat Şehir İçi Nakliyat
Paribu Güvenilir mi
Ankara Fayans Ustası
6E0CD
ReplyDeleteGiresun Şehirler Arası Nakliyat
Ardahan Şehirler Arası Nakliyat
Pancakeswap Güvenilir mi
Niğde Şehirler Arası Nakliyat
Denizli Şehir İçi Nakliyat
Amasya Lojistik
Isparta Evden Eve Nakliyat
Trabzon Evden Eve Nakliyat
Kırşehir Lojistik
D52B9
ReplyDeleteSiirt Parça Eşya Taşıma
Çerkezköy Korkuluk
Antep Şehirler Arası Nakliyat
Artvin Lojistik
Mamak Boya Ustası
Çerkezköy Parke Ustası
Kayseri Parça Eşya Taşıma
NWC Coin Hangi Borsada
Gümüşhane Lojistik
79BF0
ReplyDeletefat burner for sale
Balıkesir Evden Eve Nakliyat
order testosterone propionat
order sarms
testosterone enanthate
order primobolan
masteron for sale
Konya Evden Eve Nakliyat
Kripto Para Borsaları
9DE68
ReplyDeleteCoin Nedir
Ünye Mutfak Dolabı
Etlik Boya Ustası
Ünye Oto Boya
Çankırı Evden Eve Nakliyat
Tekirdağ Cam Balkon
Çerkezköy Oto Elektrik
Çankaya Fayans Ustası
Ünye Boya Ustası
8ECAC
ReplyDeletehttps://referanskodunedir.com.tr/
DD7A8
ReplyDeleteKripto Para Kazma Siteleri
Kripto Para Üretme Siteleri
Coin Nasıl Üretilir
Gate io Borsası Güvenilir mi
Coin Nasıl Alınır
Kripto Para Nasıl Oynanır
Bitcoin Üretme Siteleri
Binance Komisyon Ne Kadar
Binance Ne Kadar Komisyon Alıyor
293A7
ReplyDeleteParibu Borsası Güvenilir mi
Coin Nasıl Kazılır
Kripto Para Kazanma Siteleri
Binance Hangi Ülkenin
Coin Para Kazanma
Binance Neden Tercih Edilir
Coin Kazma
Kripto Para Nasıl Kazılır
Kripto Para Madenciliği Nasıl Yapılır
C6CCA
ReplyDeletebinance referans kodu
binance referans kodu
referans kimliği nedir
binance referans kodu
binance referans kodu
resimli magnet
resimli magnet
referans kimliği nedir
resimli magnet
3313A
ReplyDeleteagri bedava sohbet chat odaları
Muğla Sesli Sohbet
Muğla Görüntülü Sohbet Canlı
bartın sesli sohbet
görüntülü sohbet uygulama
erzurum görüntülü sohbet yabancı
konya yabancı görüntülü sohbet
burdur ücretsiz görüntülü sohbet
Trabzon Telefonda Sohbet
0FEB9
ReplyDeletediyarbakır parasız sohbet
diyarbakır sesli sohbet mobil
balıkesir sohbet odaları
canlı sohbet sitesi
parasız sohbet siteleri
aydın rastgele görüntülü sohbet ücretsiz
rastgele canlı sohbet
Kırıkkale Mobil Sohbet Bedava
trabzon görüntülü sohbet
8A510
ReplyDeletebybit
kripto para haram mı
canlı sohbet siteleri
bitget
kripto para nereden alınır
bitcoin giriş
coinex
vindax
bingx
E9958
ReplyDeletebingx
en eski kripto borsası
probit
mobil proxy 4g
btcturk
filtre kağıdı
btcturk
sohbet canlı
coin nasıl alınır
96833
ReplyDeletecoin nasıl alınır
mexc
paribu
toptan sabun
btcturk
bitcoin nasıl kazanılır
bibox
vindax
binance referans kodu
B14B9
ReplyDeletebinance
bingx
probit
bingx
telegram kripto
sohbet canlı
telegram türk kripto kanalları
binance referans kimliği nedir
bitcoin nasıl kazanılır
FF142
ReplyDeletebitget
mexc
rastgele canlı sohbet
gate io
kucoin
bybit
4g mobil proxy
bitcoin nasıl üretilir
referans kimligi nedir
E4C12
ReplyDeletebinance
telegram kripto kanalları
bitget
telegram kripto grupları
kredi kartı ile kripto para alma
bybit
4g mobil
bitcoin haram mı
bitcoin seans saatleri
8A239
ReplyDeletekaldıraç nasıl yapılır
cointiger
binance
mobil proxy 4g
bitget
coin nasıl alınır
gate io
bitcoin nasıl üretilir
binance ne demek
0B9B9
ReplyDeletemexc
kripto kanalları telegram
probit
bitcoin nasıl üretilir
kraken
gate io
kraken
referans kod
kizlarla canli sohbet
dsfdsfgdgbfhty
ReplyDeleteمهندس افران جدة
B6D0AEDF90
ReplyDeletegoruntulu show