Skip to content

Latest commit

 

History

History
176 lines (142 loc) · 4.98 KB

README.md

File metadata and controls

176 lines (142 loc) · 4.98 KB

AXBinder

Simple two way binding javascript, jQuery plugin

axisj-contributed

Online Demo

http://axisj.github.io/AXBinder/

dependencies

  • jQuery
  • Mustache

API

Install

<!DOCTYPE html>
<html lang="en">
<head>

	<meta charset="UTF-8">
	<title></title>
	<script src="plugins/jquery/jquery.min.js"></script>

    <!-- this mustache is imporoved version you must use this version ! -->
	<script src="plugins/mustache/mustache.js"></script>
	<script src="src/AXBinder.js"></script>

	<!-- or use min file -->
	<!-- this file include mustache
    <script src="dist/AXBinder.min.js"></script>
	-->
</head>

Methods

AXBinder.set_model(Object[, jQueryObject]) : Model

바인딩할 자바스크립트 오브젝트로 제이쿼리로 검색된 HTML dom 엘리먼트 에 바인딩합니다. 바인딩된 모델을 반환합니다.

<div id="form-target">
	<input type="text" data-ax-path="name" class="AXInput"/>
	<input type="text" data-ax-path="email" class="AXInput"/>
</div>
var obj = {
	name: "Thomas",
	email: "[email protected]"
}

var myModel = new AXBinder();
myModel.set_model(obj, $("#form-target"));

Model.set(data_path, value) : Model

data_path에 값을 변경한다. value의 타입은 (String, Number, Array, Object)를 지원.

myModel.set("name", "Seowoo");

Model.get([data_path]) : String|Number|Array|Object

data_path에 값을 반환한다. data_path 가 없으면 전체 Object를 반환한다.

var value = myModel.get("name"); // Seowoo

Model.onchange(data_path, callBack) : Model

data_path에 값이 변경되는 이벤트 발생하면 callBack을 실행합니다.

myModel.onchange("name", function () {
    console.log(this);
    // el: domElement - 변경이 발생한 엘리먼트, 엘리먼트로 부터 다양한 속성을 추출할 수 있다.
    // jquery : jQueryObject
    // tagname: "input"
    // value: "changed value"
    console.log(this.el.id);
});
myModel.onchange("*", function (n) {
    console.log(n);
    // console.log(this); 와 동일
});

Model.onclick(data_path, callBack) : Model

data-ax-repeat="list" 속성이 부여된 엘리먼트 하위에 태그중에 data-ax-repeat-click 속성을 가진 아이템에 대해 클릭 이벤트 발생하면 callBack을 실행합니다.

myModel.onclick("list", function () {
    console.log(this);
    /*
    el: domElement
    jquery: jQueryObject
    item: Object - repeat item
    item_index: "0" - index of item
    item_path: "list[0]" - repeat data_path
    repeat_path: "list"
    tagname: "button"
    value: "add"
    */
});

Model.add(repeat_path, Object) : Model

data-ax-repeat="list" 하위아이템을 추가합니다.

myModel.add("list", {a:1});

Model.remove(repeat_path, index) : Model

data-ax-repeat="list" 하위 아이템을 제거합니다. 단! 이 때 ADDED 값을 가진 아이템은 제거하고 그렇지 않은 아이템은 DELETED 값을 아이템에 추가합니다.

myModel.remove("list", 0);

Model.update(repeat_path[, index, Object]) : Model

data-ax-repeat="list" 하위 아이템을 교체합니다.

myModel.update("list", 0, {a:1});

Model.child_add(repeat_path, repeat_item_index, child_key, Object) : Model

data-ax-repeat="list" 하위 아이템중 child_key의 하위아이템을 추가합니다.

myModel.child_add("list", 0, "child", {a:1});

Model.child_remove(repeat_path, repeat_item_index, child_key, child_index) : Model

data-ax-repeat="list" 하위 아이템중 child_key의 하위아이템을 제거합니다. 단! 이 때 ADDED 값을 가진 아이템은 제거하고 그렇지 않은 아이템은 DELETED 값을 아이템에 추가합니다.

myModel.child_remove("list", 0, "child", 0);

Model.child_update(repeat_path, repeat_item_index, child_key, child_index, Object) : Model

data-ax-repeat="list" 하위 아이템중 child_key의 하위 아이템을 교체합니다.

myModel.child_update("list", 0, "child", 0, {a:1});

Model.onupdate(data_path, callBack) : Model

this.model.onupdate("moderator", function () {
    AXInput.alignAllAnchor();
    $('#moderator-add').val('');

    $moderator.find('[data-role-user-btn]').unbind("click").bind("click", role_user_btn_onclick);
});

Model.validate() : Object

data-ax-validate 를 가진 엘리먼트에 대해 값을 검사하고 값이 없거나 짦은 경우 error를 리턴합니다.

<input type="text" data-ax-path="q" data-ax-validate="required" 
    title="이름" maxlength="8" class="AXInput W150" value=""/>
var rs = myModel.validate(), _s;
console.log(rs); // 결과를 체크 해보세요
if(rs.error) {
    _s = rs.error[0].jquery.attr("title");
    alert("" + _s + "(은)는 필수 입력사항입니다." + _s + "(을)를 입력하세요");
    rs.error[0].el.focus();
    return;
}