Skip to content

Latest commit

 

History

History
725 lines (484 loc) · 11.7 KB

README.md

File metadata and controls

725 lines (484 loc) · 11.7 KB

jAsper

大意

jAsper 是一套類似 jQuery 的 JavaScript 大型函式庫。目前已經停止開發與維護,但仍可使用。建議作為研究用途。

索引

.attr

新增標籤(Attribute)到指定元素上。

jA('#hello').attr('data-item-name', 'helloWorld');

.removeAttr

移除指定元素的特定標籤(Attribute)。

jA('#hello').removeAttr('data-item-name');

.val

設置一個元素的值,如果傳入的值是空的則為取得該元素的值。

// 設置。
jA('input').val('Yolo!!');
// 獲取。
jA('input').val();

.empty

清空一個元素的 HTML 或是值。

jA('input').empty();

.text

替一個元素設定裡面的文字,如果沒有文字傳入,則是取得該元素的文字。

jA('div').text('嗨嗨!');

.html

替一個元素設定裡面的 HTML,如果沒有 HTML 傳入,則是取得該元素的 HTML。

jA('div').html('<span>嗨嗨!</span>');

.fdPush

將物件的內容全部推送進 FormData 中。

var fd = new FormData();
    fd = jA(fd).fdPush
    ({
        username: "YamiOdymel",
        password: "dIk#NcLe"
    })

.map

和 ES 的陣列 map 用法相同。

jA([1, 2, 3, 4, 5]).map(function(){
    return true
})

.cssAnimate

進行 CSS 動畫,很適合用在 Animate.css。

jA('div').cssAnimate('fadeIn', function()
{
    alert('動畫結束!');
});

.css

替元素設置或移除單個、多個 CSS 屬性。

// 獲取。
jA('div').css("width")
// 設置。
jA('div').css("width", "300px")
// 設置多個。
jA('div').css
({
    "width" : "300px",
    "height": "600px"
})

.hasClass

檢查元素是否有該類別(Class)名稱。

jA('div').hasClass('ts button');

.classList

回傳元素的類別陣列。

var list = jA("div").classList()

.addClass

替元素加上單個、多個樣式類別。

jA('div').addClass('fitted button large');

.removeClass

替元素移除單個、多個樣式類別。

jA('div').removeClass('large');

.toggleClass

替元素切換單個、多個樣式類別。

jA('div').toggleClass('bold smile button large');

.getCss

取得元素的已計算樣式。

var width = jA("div").getCss("width")

.wrap

將目前元素用一個指定元素包起來。

jA('#hello').wrap('<section>');

.append

在目前元素後面新增一個元素。

jA('#hello').append('<span>我很好。</span>');

.after

在目前元素後面以 HTML 新增一個元素。

jA('#hello').after('<div id="world">世界!</div>');

.before

在目前元素前面以 HTML 新增一個元素。

jA('#hello').before('<div id="world">世界!</div>');

.prepend

在目前元素前面以 HTML 新增一個元素。

jA('#hello').prepend('<span>我很好。</span>');

.appendTo

將目前的元素移動到指定元素的後面。

jA('.foo').appendTo('#bar');

.prependTo

將目前的元素移動到指定元素的前面。

jA('.foo').prependTo('#bar');

.insertAfter

將目前的元素插入到指定元素的後面。

.insertBefore

將目前的元素插入到指定元素的前面。

.template

取得 <template> 的內容。

.clone

複製元素。

.remove

移除元素。

.children

取得元素的子節點。

.find

在目前的元素中搜尋指定節點。

.parent

取得目前元素的父節點。

.parents

取得目前元素的所有父節點。

.closest

取得此元素的指定父節點。

.contains

此元素是否含有我們指定的子節點。

.next

取得此元素的下一個元素。

.prev

取得此元素的上一個元素。

.validate

以 HTML5 驗證該元素。

.hide

隱藏元素。

jA('div').hide();

.show

顯示元素。

jA('div').show();

.isHidden

元素是否正處於隱藏狀態。

jA('div').isHidden();

.toggle

切換元素的顯示狀態,如果是隱藏的則顯示,反之。

jA('div').toggle();

.mousedown

當滑鼠按下的事件綁定。

.mouseup

當滑鼠放開的事件綁定。

.keyup

當按鍵放開的事件綁定。

.mousemove

當滑鼠移動的事件綁定。

.click

按下並放開的事件綁定。

.dragstart

當拖曳開始的事件綁定。

.longPress

長按事件綁定。

.trigger

觸發指定事件。

.scrollBottom

捲軸卷到底的事件綁定。

.ready

當網頁已經準備的事件綁定。

.focus

聚焦目前元素。

.isBottom

是否已經捲到元素的最底部。

.delayKeyup

延遲按鍵放開,在搜尋功能時非常有用。

.on

綁定事件監聽器。

.one

綁定僅觸發一次的事件監聽器。

.off

移除指定的事件監聽器。

.avgColor

將圖片轉換成 Canvas 然後取得其中的平均色。

.dropzone

在目前元素監聽檔案的丟放事件。

.genDate

生成年、月、日還有指定方向。

.urlParam

取得網址的單個、多個參數。

.formExplode

將一個表單的內容轉換成 FormData 格式。

jA('form').formExplode();

.formValidate

以 HTML5 驗證表單欄位。

jA('form').formValidate(
{
    username:
    {
        minlength: usernameTooShort(),
        maxlength: usernameTooLong()
    },
    password:
    {
        minlength: passwordTooShort(),
        maxlength: passwordTooLong()
    },
    email:
    {
        email    : emailIncorrect()
    }
});

.serialize

將表單轉換成參數字串。

jA('form').serialize();

.load

透過 XHR 讀取 HTML 內容,然後替換到這個元件內的內容。

jA.ajax

在非換頁的情況下傳遞 HTTP 請求取得資訊。

jA.getJSON

簡易型的 ajax,用以取得遠端 JSON 資料。

jA.xhrResponse

取得 XHR(AJAX)中的回應內容

jA.pjax

透過 AJAX 來取得下一頁的頁面內容並且套用到目前的頁面上,這可以讓網頁不需重新整理就能達到換頁的效果,亦可更換頁面的局部畫面。

jA.post

ajax 中以 POST 送出的簡寫函式。

jA.patch

ajax 中以 PATCH 送出的簡寫函式。

jA.delete

ajax 中以 DELETE 送出的簡寫函式。

jA.put

ajax 中以 PUT 送出的簡寫函式。

jA.get

ajax 中以 GET 送出的簡寫函式。

jA.sse

專門處理 Server Sent-Event 的函式。

jA.cookie

設置、編輯、移除 Cookie。當傳入的值是空白的時候會取得該 Cookie,如果傳入的選項是 -1 那麼則是移除該 Cookie。選項接受 expiresdomainpath

jA.binder

一次綁定多個事件和元素。

jA.binder(
{
    'click             | .hello': this.commentToolbar,
    'click             | .world': this.newMeow,
    'cut paste keydown | #test' : this.delayedResizeTextarea,
    'submit            | form'  : this.newComment
}, true);

jA.geo

取得使用者的地理位置,並且將資料回傳給 Callback。

授權

MIT © Yami Odymel