Jak zaimplementować * obiekt * dla ulepszenia mojego przykładowego programu javascript

Celem tej pracy jest zrozumienie znaczenia niektórych z nichobiekt koncepcja słyszałem arround.

O nagrodach

Jest na to wiele różnych sposobów / sposobów.

Mójpróbuje nie są naprawdę czyste: do dodania 2-go zegara, z inną strefą czasową, muszę edytować 3 różne miejsca. To nie jest dobre (patrz na dole odpowiedzi).

Jak mogłem zrobić coś więcej?przydatny?

Na początku:

Opublikował: początkowe pytanie dotyczyło wyboru między jquery i mootools, teraz wybór został dokonany; celem jest poprawa tego, za pomocąmootools.

Jest mała próbka / demo, które napisałem, aby grać z javascript i svg:

var cx  =128;
var cy  =128;
var slen=120;
var mlen=116;
var hlen= 80;
var selem;
var melem;
var helem;
function setvars() {
    selem=document.getElementById("seconds");
    melem=document.getElementById("minutes");
    helem=document.getElementById("hours");
    drawtime();
};
function drawtime() {
    var now=new Date();
    var nows=now.getTime()%60000;
    var nowm=now.getMinutes()*1.0+1.0*nows/60000;
    var nowh=now.getHours()*1.0+1.0*nowm/60;
    var sposx=cx + slen * Math.sin( nows / 30000 * Math.PI );
    var sposy=cy - slen * Math.cos( nows / 30000 * Math.PI );
    var mposx=cx + mlen * Math.sin( nowm / 30 * Math.PI );
    var mposy=cy - mlen * Math.cos( nowm / 30 * Math.PI );
    var hposx=cx + hlen * Math.sin( nowh / 6 * Math.PI );
    var hposy=cy - hlen * Math.cos( nowh / 6 * Math.PI );
    selem.setAttribute("x1",sposx);
    selem.setAttribute("y1",sposy);
    selem.setAttribute("x2",sposx);
    selem.setAttribute("y2",sposy);
    melem.setAttribute("x2",mposx);
    melem.setAttribute("y2",mposy);
    helem.setAttribute("x2",hposx);
    helem.setAttribute("y2",hposy);
    window.setTimeout(drawtime,80)
};
setvars();
#box1    { stroke: black; }
#minutes { stroke: #2266AA; }
#hours   { stroke: #3388CC; }
#seconds { stroke: #CCCC22; }
line,circle {
    opacity:0.65;
    fill:none;
    stroke-width:8;
    stroke-linecap:round;
    stroke-linejoin:round;
    marker:none;
    stroke-miterlimit:4;
    stroke-dasharray:none;
    stroke-opacity:1;
    visibility:visible;
    display:inline;
    overflow:visible;
    enable-background:accumulate
}
<svg xmlns="http://www.w3.org/2000/svg" id="svg2" width="100%"
     height="100%" viewBox="0 0 900 256" version="1.0">
    <title  id="title1">Clock</title>
    <circle id="box1"    cy="128" cx="128"  r="124" />
    <line   id="hours"   x1="128" y1="128" x2="128"  y2="48" />
    <line   id="minutes" x1="128" y1="128" x2="244" y2="128" />
    <line   id="seconds" x1="128"   y1="8" x2="128"   y2="8" />
</svg>

(Originaly napisał najsfiddle) ponieważ nie jestem zbytnio doświadczony w jquery i / lub mootools javascript, chciałbym wiedzieć, czy istnieją jakieś prostsze metody, być może w pisaniu tego w inny sposób.

jak zrobić prostą rotację wokół stałego centrum, używając jquery lub mootools:

var hposx=cx + hlen * Math.sin( nowh / 6 * Math.PI );
var hposy=cy - hlen * Math.cos( nowh / 6 * Math.PI );
helem.setAttribute("x2",hposx);
helem.setAttribute("y2",hposy);

jakzobiektywizować ten kod? (jeśli nawet to mogłoby być dobre) ...

Wszystkie próbki wykorzystujące orientację obiektu, określoną bibliotekę lub inne są mile widziane!

questionAnswers(4)

yourAnswerToTheQuestion