Handlebars 도우미를 사용하여 객체 세트를 구문 분석하고 반환 된 결과를 #linkTo 호출로 감싸서 Embers 라우터가 가져 오도록합니다. 여기사용자 정의 Handlebars 도우미 내에서 linkTo 사용
내가보기에서 전화 드렸습니다 방법은 다음과 같습니다
Ember.Handlebars.registerHelper 'buildBreadcrumb', (val, opts) ->
value = Ember.get(this, val)
out = ""
value.forEach (group, index) =>
if value.length - index == 2
out += '{{#linkTo group ' + group.name + '}}'
if value.length - index == 1
out += '{{#linkTo group ' + group.name + '}}'
out
위의 단지 분명한 이유 리터럴 문자열로 {{#linkTo ...}}
을 구문 분석 : {{buildBreadcrumb my_objects}}
여기처럼 내 도우미 모습입니다. 내가 그것을 찾고있는 방식으로 구문 분석 할 수있는 방법이 있습니까? 저는 뷰 자체에서 {{#each}} 등등을 사용할 수 있다는 사실을 잘 알고 있습니다.하지만 사용 사례 때문에 헬퍼를 사용해야합니다. 어떤 제안?
나는 당신의 노력 덕분에 당신의 답변을 upvoted - 나는 그것을 주셔서 감사합니다. 가장 큰 문제는 항목을 반복하고 링크를 만드는 것이 아니라는 것입니다 (간단한 # 각 호출을 통해 설명 할 수 있음을 보여주었습니다). 내 문제는 배열의 마지막 두 항목 만 표시하고 싶다는 것입니다. 전체 탐색 경로를 원하지 않습니다. 그래서 위의 예제 코드에서 항목의 인덱스를 확인합니다. 당신이 준 예를 가지고 그것을 할 수있는 어떤 방법? – John
물론, 특정 인덱스에있는 항목을 가리키는 계산 된 속성을 사용하여 템플릿의 해당 속성을 사용할 수 있습니다. 업데이트 된 코드를 참조하십시오. –
감사합니다. 그건 완벽하게 작동합니다. – John