Sharepoint custom field

среда, 4 июня 2008 

Реально динамически-вычисляемого поля в Sharepoint-е создать нельзя! Ибо можно лишь задать некие условия для вычисления значений, но они вычисляются только раз.
И тому подтверждение множества линков под катом, с вариацией на тему создания custom field.

P.S. Смотрите комментарии…

Комментарии

rss
Alex [ответить]  [свернуть]
12:53, 28 июня 2008

В данном случае Автор не прав. Можно создать динамически-вычисляемого поле которое вычисляет свое значение (Custom field type) на основе других полей но для этого потребуются дополнительные усилия в виде написания Field Type Definition xml файла где можно реализовать логику по вычислению значения поля (JavaScript). В очень сложных вариантах можно использовать Ajax-технолигию (xmlHttpRequest) по получению значения.

Pash [ответить]  [свернуть]
13:13, 28 июня 2008

Уважаемый Alex
В данном посте имелось ввиду что нельзя создать поле значение, которого каждый раз вычисляется на стороне сервера, при выдаче так сказать. JavaSript-ом на стороне клиента можно подгрузить вообще всё что угодно, но разве это правильно красиво? :)

 
 
Alex [ответить]  [свернуть]
13:18, 28 июня 2008

Ajax-технолигию (xmlHttpRequest) можно использовать для вызова web-service method’а который будет вычислять наше значение.

С уважением,
Alex

Pash [ответить]  [свернуть]
13:28, 28 июня 2008

C Ajax-м всё понятно, только для каждого поля тянуть данные с сервака…
Хотя можно придумать и некую очередь чтобы делать один запрос по множеству полей…
В общем это вариант создания динамического поля, только он не родной так сказать, а всё как-то больше с боку. А пост был (по крайне мере я его так видел) в контексте Lookup & Calculated fields.

Тем не менее, спасибо за идеи!

 
 
Alex [ответить]  [свернуть]
13:48, 28 июня 2008

Ajax это для “тяжелых” полей, а так Field Type Definition xml файл в самый раз, тем более что для заказчика важен результат, а что за кадром - это проблема того кто разрабатывает :D

P.S.
Приятно узнать что у нас в РБ есть сайт с SharePoint тематикой.

 
Pash [ответить]  [свернуть]
14:07, 28 июня 2008

Мне в свою очередь приятно что кто-то (я так понимаю у нас в РБ) также интересуется SharePoint-м.

Однако, при такой реализации динамичного поля, встаёт вопрос — что будет с такими динамичными полями при экспорте листа?…

 
Alex [ответить]  [свернуть]
15:15, 28 июня 2008

Да, как я посмотрел, при экспорте листа данные не передаются, но думаю ситуация решаемая. Первый способ которой приходит в голову организация собственного export-workflow.

А насчет РБ - да я нахожусь в Минске.
Сейчас занимаюсь Publishing-ом и SharePoint Designer 2007. Оказалась довольно таки хорошей вещью после более пристального внимания :D

Alex

Pash [ответить]  [свернуть]
15:39, 28 июня 2008

Вот к сожалению и получается, что решение не нативное и как результат надо будет во многих многих местах перекрывать функционал.
По крайне-мере если это делать для полноценного листа. Зато такой подход можно использовать в каких-либо более иных местах, webpart-х, аль ещё где.

 
 
Alex [ответить]  [свернуть]
18:04, 28 июня 2008

Не согласен. Думаю причина в том что в классе отвечающий за этот мой field не переопределен метод GetValue (в моем случае мне не нужен был export как таковой и GetValue возвращает пустую строку тк класс наследовался от SPTextField). Так что решение все таки native.

Alex

Pash [ответить]  [свернуть]
18:40, 28 июня 2008

Насколько мне помнится вызов GetValue не будет происходить каждый раз при обращении к данным. Т.е. актуальность данных будет весьма сомнительная.
Надо бы проверить, но под рукой нет ничего такого, я ваять пример сейчас нет желания. Но возможно понедельник расставит всё на свои места.
Удачного выходного!

 
 

Комментаформа

For spam filtering purposes, please copy the number 9694 to the field below:

Навигационное древо

Каталог

Будет всякого разного:
Copyright © 2007 Шапель Павел.
Powered  by