SharePoint - funkcje i elementy
W tym rozdziale przyjrzymy się funkcjom i elementom. Funkcje są pod pewnymi względami modelem składników w programie SharePoint. Pozwalają zdefiniować logiczne jednostki funkcjonalności.
Na przykład możesz chcieć mieć w witrynie możliwość -
Aby utworzyć listę z określonym schematem,
Przygotuj stronę, która pokaże dane z tej listy, a następnie
Umieść link lub opcję menu gdzieś w witrynie, aby przejść do tej strony.
Możesz stworzyć funkcję, która definiuje logiczne zgrupowanie funkcjonalności. Poszczególne elementy funkcjonalności są definiowane przez elementy.
Byłby więc element, który -
Tworzy listę i ustawia schemat.
Udostępnia stronę w witrynie SharePoint, a
Tworzy opcję menu lub łącze.
Cecha definiuje jednostkę, a następnie elementy definiują poszczególne elementy funkcjonalności wewnątrz tej jednostki. Omówiliśmy trzy rodzaje elementów -
Instancja listy służąca do tworzenia listy.
Moduł do obsługi administracyjnej strony.
Akcja niestandardowa służąca do tworzenia opcji menu lub łącza.
Istnieje jednak wiele innych rodzajów elementów, które można tworzyć w programie SharePoint. Inną ważną koncepcją dotyczącą funkcji, którą należy zrozumieć, jest aktywacja i dezaktywacja.
Na przykład, jeśli użytkownik końcowy chce, aby wyżej wymieniona funkcjonalność została dodana do jego witryny, aktywowałby odpowiednią funkcję, która utworzyłaby listę, dodał opcję menu lub łącze i udostępnił stronę w swojej witrynie. Później mógł wyłączyć tę funkcję, aby ją usunąć.
Należy zauważyć, że po dezaktywacji funkcji niektóre elementy są automatycznie usuwane. Na przykład SharePoint automatycznie usunie opcję menu lub łącze zdefiniowane przez akcję niestandardową.
Inne nie są usuwane automatycznie. Dlatego w naszym przypadku instancja listy i strona nie zostaną usunięte automatycznie.
Dlatego jako programista musisz zrozumieć, które elementy są usuwane automatycznie, a które nie. Jeśli chcesz usunąć te, które nie są usuwane automatycznie, możesz napisać kod w plikufeature receiver.
Przyjrzyjmy się pracy z funkcjami i elementami. Zaczniemy od poglądu użytkowników końcowych na funkcje.
Step 1 - Otwórz witrynę SharePoint.
Step 2 - Aby przejść do ustawień Witryny, masz dwa łącza, które umożliwiają zarządzanie funkcjami.
Pierwszy link Manage Site features znajduje się w obszarze Akcje witryny, co umożliwia zarządzanie funkcjami zakresu witryny.
Drugi link Site collection features w obszarze Administracja zbiorem witryn, która umożliwia zarządzanie funkcjami zakresu zbioru witryn.
Step 3- Kliknięcie któregokolwiek z tych linków spowoduje przeniesienie do strony, która pokazuje aktualnie aktywne i nieaktywne funkcje. W przypadku każdej funkcji można ją aktywować lub dezaktywować.
Spójrzmy na prosty przykład, tworząc nowy pusty projekt SharePoint Solutions.
Step 1 - Nazwijmy to FeaturesAndElements i kliknij OK.
Step 2 - Określ witrynę, której chcesz użyć, i wybierz plik Deploy as a farm solution opcję, a następnie kliknij przycisk Zakończ.
Pierwszą rzeczą, którą chcemy stworzyć, jest funkcja. W Eksploratorze rozwiązań można zobaczyć folder Funkcje, który jest obecnie pusty.
Step 3 - Kliknij prawym przyciskiem myszy plik Features folder i wybierz Add Feature. Tworzy funkcję o nazwieFeature1i otwiera projektanta funkcji. Domyślny tytuł to tytuł projektu plus tytuł funkcji.
Step 4 - Zmień nazwę funkcji z Feature1 na Sample.
Tytuł i opis to to, co użytkownik widzi na stronie, na której aktywują i dezaktywują funkcje.
Ustaw tytuł na Sample Feature i opis do Adds the Contacts list and the page is used to view the list. Inną rzeczą, którą musimy ustawić, jest zakres funkcji, czyli zakres aktywacji.
Może to być farma, aplikacja internetowa, zbiór witryn lub witryna. W tym przypadku przygotujemy listę i stronę. Ponieważ obaj mieszkają w witrynie SharePoint, wybierzemy tutaj sieć Web.
Step 5- Zacznijmy dodawać funkcje w naszych elementach. Pierwszym elementem będzie lista, a my utworzymy listę kontaktów. Kliknij projekt prawym przyciskiem myszy i wybierzAdd → New Item...
Step 6- Wybierz opcję Lista w środkowym okienku i wprowadź Kontakty w polu nazwy. Kliknij Dodaj.
Step 7- Pojawi się Kreator tworzenia listy. Utwórz listę o nazwie Kontakty na podstawie listy kontaktów. Kliknij Zakończ, aby utworzyć listę lub przynajmniej utworzyć element, który ostatecznie utworzy listę.
Poniżej przedstawiono zrzut ekranu projektanta listy.
Step 8- Ten projektant to tylko edytor XML. Otwórz plik Elements.xml w sekcji Kontakty i dodaj następujące dane.
<?xml version = "1.0" encoding = "utf-8"?>
<Elements xmlns = "http://schemas.microsoft.com/sharepoint/">
<ListInstance Title = "Contacts" OnQuickLaunch = "TRUE" TemplateType = "105"
FeatureId = "00bfea71-7e6d-4186-9ba8-c047ac750105"
Url = "Lists/Contacts" Description = "">
<Data>
<Rows>
<Row>
<Field Name = "ID">1</Field>
<Field Name = "Last Name">Anders</Field>
<Field Name = "First Name">Maria</Field>
<Field Name = "Company">Alfreds Futerkiste</Field>
<Field Name = "Business Phone">030-0074321</Field>
</Row>
<Row>
<Field Name = "ID">2</Field>
<Field Name = "Last Name">Hardy</Field>
<Field Name = "First Name">Thomas</Field>
<Field Name = "Company">Around the Horn</Field>
<Field Name = "Business Phone">(171) 555-7788</Field>
</Row>
<Row>
<Field Name = "ID">3</Field>
<Field Name = "Last Name">Lebihan</Field>
<Field Name = "First Name">Laurence</Field>
<Field Name = "Company">Bon app'</Field>
<Field Name = "Business Phone">91.24.45.40</Field>
</Row>
<Row>
<Field Name = "ID">4</Field>
<Field Name = "Last Name">Ashworth</Field>
<Field Name = "First Name">Victoria</Field>
<Field Name = "Company">B's Beverages</Field>
<Field Name = "Business Phone">(171) 555-1212</Field>
</Row>
<Row>
<Field Name = "ID">5</Field>
<Field Name = "Last Name">Mendel</Field>
<Field Name = "First Name">Roland</Field>
<Field Name = "Company">Ernst Handel</Field>
<Field Name = "Business Phone">7675-3425</Field>
</Row>
</Rows>
</Data>
</ListInstance>
</Elements>
Zwróć uwagę na następujące kwestie -
W środku ListInstance element, mamy element o nazwie Data i ma w sobie kilka rzędów.
ListInstance będzie mieć atrybuty Contacts, czy pokażemy się w szybkim uruchomieniu.
Chcemy listy opartej na szablonie kontaktów. Tutaj,TemplateType jest ustawione na 105. To nie jest liczba losowa, ale liczba o znaczeniu.
Każdy z domyślnych rodzajów list, które można mieć w programie SharePoint, takich jak lista ogłoszeń, lista zadań, lista kontaktów itd., Ma przypisany numer. Dlatego jeśli zmienisz 105 na 107, otrzymasz inny rodzaj listy.
FeatureId jest poradnikiem związanym z definicją listy kontaktów.
Step 9- Teraz chcemy mieć stronę, która pokazuje dane z tej listy. Kliknij projekt prawym przyciskiem myszy i wybierzAdd → New Item... Wybierz Moduł w środkowym panelu, wprowadź SitePage w polu nazwy i kliknij Add.
Zobaczysz węzeł o nazwie SitePage, który ma dwa pliki, Elements.xml i Sample.txtplik. Nie chcemy udostępniać tego pliku sample.txt, ale chcemy udostępnić stronę SitePage.
Step 10 - Zmień nazwę pliku tekstowego na Contacts.aspx i zamień następujący kod -
<%@ Assembly Name = "Microsoft.SharePoint, Version = 14.0.0.0, Culture = neutral,
PublicKeyToken = 71e9bce111e9429c" %>
<%@ Page MasterPageFile = "~masterurl/default.master"
meta:progid = "SharePoint.WebPartPage.Document" %>
<%@ Register TagPrefix = "SharePoint"
Namespace = "Microsoft.SharePoint.WebControls"
Assembly = "Microsoft.SharePoint, Version = 14.0.0.0, Culture = neutral,
PublicKeyToken = 71e9bce111e9429c" %>
<asp:Content ID = "Content2" runat = "server" ContentPlaceHolderID = "PlaceHolderMain">
<SharePoint:SPDataSource runat = "server"
ID = "ContactsDataSource" DataSourceMode = "List"
UseInternalName = "false">
<SelectParameters>
<asp:Parameter Name = "ListName" DefaultValue = "Contacts" />
</SelectParameters>
</SharePoint:SPDataSource>
<SharePoint:SPGridView runat = "server"
ID = "ContactsGridView" DataSourceID = "ContactsDataSource"
AutoGenerateColumns = "false" RowStyle-BackColor = "#DDDDDD"
AlternatingRowStyle-BackColor = "#EEEEEE">
<Columns>
<asp:BoundField HeaderText = "Company"
HeaderStyle-HorizontalAlign = "Left" DataField = "Company" />
<asp:BoundField HeaderText = "First Name"
HeaderStyle-HorizontalAlign = "Left" DataField = "First Name" />
<asp:BoundField HeaderText = "Last Name"
HeaderStyle-HorizontalAlign = "Left" DataField = "Last Name" />
<asp:BoundField HeaderText = "Phone"
HeaderStyle-HorizontalAlign = "Left" DataField = "Business Phone" />
</Columns>
</SharePoint:SPGridView>
</asp:Content>
<asp:Content ID = "PageTitle" ContentPlaceHolderID = "PlaceHolderPageTitle"
runat = "server">
Contacts
</asp:Content>
<asp:Content ID = "PageTitleInTitleArea"
ContentPlaceHolderID = "PlaceHolderPageTitleInTitleArea" runat = "server" >
Contacts
</asp:Content>
SitePage ma rozszerzenie SP.DataSourceplik, którego użyjemy do utworzenia danych listy kontaktów, coś, do czego możemy się powiązać na naszej stronie. PlikSP.GridView pokaże informacje o kontaktach.
To jest nasza strona internetowa, a teraz przyjrzyjmy się funkcji.
Zauważ, w Items in the Feature, Wystąpienie listy kontaktów i udostępnianie modułu na naszej stronie witryny zostały dodane jako elementy.
Program Visual Studio rozumie, że elementy same w sobie nie mogą nic zrobić. Elementy muszą być częścią cechy. Dlatego kiedy dodajesz element, musisz dodać go do elementu.
Step 11 - Przejdź do swojego projektu, kliknij prawym przyciskiem myszy i wybierz Add → New Item...
Tutaj chcemy dodać CustomAction, więc wybierz Empty Element w środkowym okienku, wywołaj tę akcję, a następnie kliknij Add.
Jeśli wrócisz do swojej funkcji, zobaczysz, że element został teraz dodany do funkcji, jak pokazano na zrzucie ekranu podanym poniżej.
Step 12 - Wróć do Elements.xml w obszarze Akcja i zamień następujący kod -
<?xml version = "1.0" encoding = "utf-8"?>
<Elements xmlns = "http://schemas.microsoft.com/sharepoint/">
<CustomAction
Id = "SiteActionsToolbar"
GroupId = "SiteActions"
Location = "Microsoft.SharePoint.StandardMenu"
Sequence = "100"
Title = "Contacts"
Description = "A page showing some sample data">
<UrlAction Url = "~site/SitePages/Contacts.aspx"/>
</CustomAction>
</Elements>
Teraz, jeśli chcesz dodać łącze lub opcję menu, musisz zdefiniować, gdzie chcesz je dodać i jest to kombinacja lokalizacji i GroupId, które je definiują. Ta kombinacja wartości wskazuje, że opcja menu powinna zostać dodana do menu SiteActions.
Istnieje wiele innych kombinacji wartości, które dodają łącze lub menu w innych miejscach w naszej witrynie SharePoint. To jest coś, co musisz zbadać, aby dowiedzieć się, jaka jest właściwa kombinacja wartości, której potrzebujesz, gdy chcesz dodać opcję menu gdzieś w programie SharePoint.
Step 13 - Kliknij dwukrotnie plik Feature, zobaczysz projektanta funkcji. Projektant funkcji to fantazyjny edytor Manifestu funkcji, który jest dokumentem XML.
Ważne punkty -
Cecha definiuje logiczne grupowanie elementów. Tutaj nasza Cecha odnosi się do naszych trzech manifestacji elementów, które właśnie stworzyliśmy.
Po aktywowaniu funkcji SharePoint spojrzy na manifest pojedynczego elementu i doda listę, stronę i łącze do naszej witryny SharePoint.
Podczas wdrażania przy użyciu programu Visual Studio automatycznie aktywuje wszystkie funkcje w projekcie. Ponieważ chcemy przejść przez proces aktywacji funkcji, zamierzamy powiedzieć programowi Visual Studio, aby tego nie robił.
Step 14- Przejdź do właściwości projektu, przechodząc do karty SharePoint. Zmień konfigurację wdrażania naNo Activation.
Przetestujmy to.
Step 15 - Kliknij prawym przyciskiem myszy projekt w Eksploratorze rozwiązań i wybierz Deploy. Spakuje wszystkie elementy projektu i wdroży je w farmie rozwoju SharePoint.
Po pomyślnym wdrożeniu zobaczysz go w oknie Dane wyjściowe.
Step 16- Przejdź do witryny SharePoint i odśwież ją. Przejdź doSite Settings → Site Actions.
Step 17 - Wybierz opcję Zarządzaj funkcjami witryny, ponieważ Twoja funkcja niestandardowa miała zasięg sieciowy, a zobaczysz swój Sample Feature. Widać, że ta funkcja nie została aktywowana, więc przejdźmy dalej i aktywujmy ją.
Zobaczysz listę kontaktów w lewym okienku.
Step 18 - Kliknij Kontakt, a zostaną wyświetlone dane, które mieliśmy na liście.
Step 19- Przejdź do menu działań witryny. Istnieje możliwość przejścia do strony Kontakty. To jest nasza CustomAction.
Step 20 - Jeśli klikniesz opcję Kontakty, zostanie wyświetlona strona witryny zawierająca dane z listy kontaktów.