mėnesio Archyvai: Sausio 2015

HTTP 406 Klaida, kai naudojant kampinis $http.get nuo SharePoint poilsio hipotezes

Atnaujinimas: Marc AD ndersson nurodė šį puikus gabalas, info: http://blogs.Office.com/2014/08/13/JSON-Light-support-Rest-SharePoint-API-Released/. Tai paaiškina daug :).

Tai gali būti blogiausiu žinutę pavadinimas kada nors! Anyhoo.

Paprastai aš visus mano prototipų prieš O365 egzempliorius. Aš turiu mano asmens instancijos, kad man nereikės nerimauti dėl įtakos kas nors. Kaip panaikinti – prisiminti Kada mes vadiname atliktas aplink virtualios mašinos mūsų nešiojamieji kompiuteriai su MOSS – SQL serverio, IIS, SPRENDŽIAMOSIOS Hyper-V vs. VMWare? Anyhoo...

Man buvo sukurtas naudojant judesio kiekio šioje aplinkoje, kuri nėra app, be kita ko, tai:

$http.get(serverUrl)
.sėkmės(funkcija(duomenų, statusas, antraštės, Config) {

var getLinksResponse = duomenys;

getLinksResponse.value.forEach(funkcija(theResult) {

// ir taip puta

Tai dirbo tik baudą dviejų skirtingų SharePoint online aplinkoje. Tačiau, Kada mano kolega jis perkeltas į Cloudshare instancijos, jis buvo gauti, HTTP 406 klaida (kuris buvo pirmą kartą aš kada nors gavo, kad vienas, Taigi... yay, tikriausiai). Mes padarėme šiek tiek mokslinių tyrimų ir pastebėjau, kad "Priimti" antraštė buvo ne. SharePoint internete buvo visiškai laimingas su:

Priimti: paraiškos/json

Bet cloudshare atveju (kuri yra SP prem, vyko virtualiame serveryje) norėjo klasikinis "odata = kalbantys" įrašyti, taip pat:

Priimti: paraiškos/json;oData = kalbantys

Nustatyti, kad, Mes pridėjome antraštėje tokiais:

var config = {antraštės: {
"Priimti": "paraiškos/json;oData = kalbantys "
}
};

$http.get(serverUrl,Config)
.sėkmės(funkcija(duomenų, statusas, antraštės, Config) {

var getLinksResponse = duomenys;

getLinksResponse.value.forEach(funkcija(theResult) {

// ir taip puta

Kad atsikratyti, kad 406, Tačiau ji taip pat pakeitė formatą, atsakymas. Tai buvo daugiau... kalbantys. (Haha!) Daugiau pakeitimų buvo reikalaujama ir Štai galutinis rezultatas:

var config = {antraštės: {
"Priimti": "paraiškos/json;oData = kalbantys "
}
};

$http.get(serverUrl,Config)
.sėkmės(funkcija(duomenų, statusas, antraštės, Config) {

var getLinksResponse = duomenys;

getLinksResponse.d.results.forEach(funkcija(theResult) {

// ir taip puta

Tai tik pasuko į a 30 minutę problema mums, Taigi mes lucked. Tikimės, kad kas nors mano, kad tai naudinga.

</pabaigos>

"Kaip?": Įgalinti kelias kampinis SharePoint žiniatinklio dalis tame pačiame puslapyje.

Šiame dienoraštyje pranešimų aprašoma, kaip jūs galite turėti kelis Angular.js pagal SharePoint žiniatinklio dalys (nuorodos per turinio rengyklės žiniatinklio dalį) tame pačiame puslapyje.. I 'm calling turinio rengyklės žiniatinklio dalį (CEWP) tyta JavaScript pastatytas naudojant Angular.js sistemą yra "kampinis žiniatinklio dalis."

Judesio kiekio 's įkrovos procesas yra itin paprasta ir beveik kiekvieną pavyzdį rasite internetas eina kažką panašaus į tai:

<HTML ng-app = "mano">

<blah /><blah /><blah />

</HTML>

Tai skyla, Tačiau, Jei norite įgalinti kelis CEWP atstovaujančių kelias kampinis žiniatinklio dalis tame pačiame puslapyje.. Judesio kiekio bus tik automatiškai įkrovos nuo pirmosios ng-app direktyvos jis nustato – bent kaip ir kampinis versija 1.3.6. Sprendimas yra labai paprastas-rankiniu būdu įkrovos kodą vietoj. Aukščiau dabar pasikeičia į kažką panašaus į tai:

<įstaiga>
<d
IV id =”bootstrapHere” NG-controller =”myController kaip theController”>
<blah /><blah /><blah />
</DIV>
</įstaiga>

<myController kaip theController”//Ajax.googleapis.com/Ajax/libs/angularjs/1.3.6/angular.js”></scenarijų>

<scenarijų>
angular.Bootstrap(angular.element(document.getElementById(“bootstrapHere”)),["mano"]);
</scenarijų>

Iš esmės, Užuot naudoję ng-app elemente daryti savo Bootstrap, jums slap ant elemento ID. Tada, Naudokite apie bootstrap() metodas, kampinis save kontroliuoti Bootstrap apdoroti run-time. Aš išbandyti tai su trijų skirtingų kampinis puslapio dalis į tą patį puslapį ir jis veikia žavesio.

</pabaigos>

undefinedPrenumeruoti savo dienoraštį.

Sekite mane Twitter ne http://www.twitter.com/pagalvin