Alloy

  • Published on
    오랜만에 티타임을 가졌다. 하루 밖에 안지났는데,.. 벌서 기억나지 않는 것들이 너무 많다.. -_-;;.. 일단 생각나는 대로 정리! Alloy 이슈들 Alloy 1.2 버전부터 ListView를 XML로도 정의할수 있게됐다. 물론 ListView는 아직 한창 개발중이기 때문에 drag 이벤트라든가 headerView나 Pulldown Refresh 기능들은 좀더 기다려야한다. 자세한 내용은 Alloy Jira 페이지를 확인해보자. ListView에 데이터 바인딩시 삽질하기 쉬운 착각들 1. 먼저 dataCollection은 ListView가 아닌 ListSection에 정의해야한다. 이 문제 때문에 삽질한 시간은 정말 눈물 겹다. TableView의 경우 dataCollection을 TableView에 정의 하지만 ListView 조금 다르다. 다음 예제를 보자. 아래와 같이 ListView에 dataCollection을 정의하면 Alloy 컴파일 오류를 발생시킨다. <ListV
  • Published on
    아직 완성된 글이 아닙니다. ---- Alloy의 모델은 Backbone의 모델을 사용하므로, Backbone의 API와 Event를 그대로 사용할수있다. 일단 스튜디오에서 Alloy모델을 생성하게 되면 /model 폴더에 해당 파일이 생성되고 기본 구조는 다음과 같다. 1. 모델의 기본 구조 exports.definition = { config : { // table schema and adapter information }, extendModel: function(Model) { _.extend(Model.prototype, { // Extend, override or implement Backbone.Model }); return Model; }, extendCollection: function(Collection) { _.extend(Collection.prototype, { // Extend, override or implement Backbone.Collection });
  • Published on
    타이타늄 3.0이 정식 릴리즈를 했고, 그동안 베타버전을 쓰면서 나타났던 문제들을 정리해본다. 1. 이유없이 에뮬레이터가 죽는 경우 Alloy를 사용하다보면 빌드하자마자 "Application has exited from Simulator" 라는 메시지를 던지면서 죽는 경우를 꼭 한번씩은 겪게 된다. 대표적인 경우가 console.log를 이용해 Alloy 모델이나 콜랙션을 그대로 출력할때 발생한다. 또 다른 예로 Fugitives 소스코드에서 29번째 라인 부근을 보면 다음과 같은 코드가 있다. var model = atLargeCollection[i]; var row = Alloy.createController(&#039;FugitiveRow&#039;, model.toJSON()).getView(); row.model = model; rows.push(row); 위 코드에서 문제가 되는 코드는 바로 3번 라인에 있는 row.model = model 코드다. 즉, Alloy 모델