środa, 11 maja 2011

Obsługa tablic asocjacyjnych w JS

Przeglądanie tablicy asocjacyjnej w JS może sprawić pewne kłopoty. Nie działa właściwość length, więc nie da się zastosować zwykłej pętli for. Natomiast przeglądanie za pomocą konstrukcji typu for(n in a), oprócz właściwych pozycji tablicy, zwraca również inne właściwości obiektu klasy Array.
Przykład:

var a = [];
a["a"] = "A";
a["b"] = "B";
a["c"] = "C";
for(n in a){
    console.log('a("' + n + '") = ' + a[n]);
}
W wyniku wykonania powyższego kodu, na konsoli (w Firebugu) ujrzymy mniej więcej takie coś:

a("a") = A
a("b") = B
a("c") = C
a("contains") = function (v) {
    if (v == null) {
        return false;
    }
    for (var i = 0; i < this.length; i++) {
        if (this[i] == v) {
            return true;
        }
    }
    return false;
}
Widać, że oprócz wartości wpisanych do tablicy, przetwarzana jest również właściwość "contains", która jest wewnętrzną właściwością obiektu klasy Array.
Cóż robić więc?
No więc jeśli mamy do czynienia z tablicą asocjacyjną, wystarczy zadeklarować ją w następujący sposób:

var a = {};

Uruchomienie powyższego przykładu z wprowadzoną taką zmianą, spowoduje wyświetlenie już tylko tych wartości, o które nam chodzi.

niedziela, 8 maja 2011

Włączanie skrolowania TrackPointem w Netbeans

Bardzo uciążliwą cechą skrolowania środkowym przyciskiem TrackPointa jest to, że nie działa w niektórych aplikacjach. Na przykład w NetBeans IDE.
Na szczęście można sobie z tym w prosty sposób poradzić.
  1. Musimy odnaleźć plik tp4Table.dat. Zależnie od wersji znajduje się w różnych katalogach. U mnie jest to c:\Program Files\Apoint2K\tp4table.dat
  2. Otwieramy go w edytorze tekstowym (na prawach administratora)
  3. Odnajdujemy w pliku następujący wiersz:
    *,*,javaw.exe,*,*,*,WheelStd,1,9
  4. kopiujemy go i wklejamy poniżej, a następnie zamieniamy napis javaw na netbeans
  5. zapisujemy plik i od razu możemy się cieszyć skrolem w NetBeans
Na początku pliku tp4table.dat jest wyjaśnienie poszczególnych ustawień. Analogicznie należy postępować w przypadku problemów ze skrolem w innych aplikacjach

środa, 16 lutego 2011

Wielowierszowe pole tekstowe

Zwykłe lotusowe pole tekstowe pod webem jest prezentowane jako pole jednowierszowe. Nie ma prostego sposobu, żeby było prezentowane jako wielowierszowe. Te są zarezerwowane dla pól richtextowych. Można jednak użyć pewnego patentu:
  1. Tworzymy pole tekstowe o nazwie Tresc i nadajemy mu id (np: tresc).
  2. Zamykamy to pole w elemencie div, który ukrywamy stosownym stylem (Zastosowanie formuł ukrywania zawodzi w tym przypadku - rozwiązanie nie działa):
    <div id="trescDiv" style="display: none;">[POLE TEKSTOWE Z PUNKTU 1]</div>
  3. Tworzymy pole tekstowe obliczane do wyświetlenia, o nazwie np. TextWeb i jako jego wartość wpisujemy:
    "[<TEXTAREA NAME='Tresc' ROWS=4 COLS=54 WRAP=VIRTUAL>" + Tresc + "</TEXTAREA>]"
  4. Po załadowaniu dokumentu, kawałkiem skryptu usuwamy pole z punktu 1.
    var n = document.getElementById("tresc");
    n.parentNode.removeChild(n);
W trybie edycji będzie w porządku, ale w trybie czytania nie bardzo. W związku z tym postępujemy następująco:
  1. Wszystko powyższe ukrywamy w trybie czytania
  2. Tworzymy computed text z formułą konwertującą nowe linie na "<br>":
    @ReplaceSubstring(Tresc; @NewLine; "<br>")
  3. Żeby powyższe zadziałało, a do tego w kliencie wyświetlało się poprawnie, musimy skonwertować znaki nowego wiersza przesyłane z przeglądarki na @NewLine. Przy zapisie dokumentu (w WebQuerySave) wykonujemy następujący skrypt:
    Doc.Tresc = Evaluate(|@ReplaceSubstring(Tresc; @Char(13); @NewLine)|, Doc)