Skip to content

Instantly share code, notes, and snippets.

@gitjeff05
Last active August 29, 2015 14:27
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save gitjeff05/dd47192ee47c9441e16b to your computer and use it in GitHub Desktop.
Save gitjeff05/dd47192ee47c9441e16b to your computer and use it in GitHub Desktop.
Component Rendering Hooks
import Ember from 'ember';
export default Ember.Component.extend({
someCondition: false,
componentName: 'some-component',
changeCondition: function() {
console.log(this.get('componentName') + ' on did insert element');
setTimeout(() => {
this.set('someCondition', true);
}, 2000)
}.on('didInsertElement'),
logRerender: function() {
console.log(this.get('componentName') + ' on will clear render.');
}.on('willClearRender'),
logDestroyElement: function() {
console.log(this.get('componentName') + ' will destroy element.');
}.on('willDestroyElement'),
logInsertElement: function() {
console.log(this.get('componentName') + ' will insert element.');
}.on('willInsertElement')
});
import Ember from 'ember';
export default Ember.Component.extend({
componentName: 'sub-component',
changeCondition: function() {
console.log(this.get('componentName') + ' on did insert element.');
}.on('didInsertElement'),
logRerender: function() {
console.log(this.get('componentName') + ' on will clear render.');
}.on('willClearRender'),
logDestroyElement: function() {
console.log(this.get('componentName') + ' will destroy element.');
}.on('willDestroyElement'),
logInsertElement: function() {
console.log(this.get('componentName') + ' will insert element.');
}.on('willInsertElement')
});
import Ember from 'ember';
export default Ember.Controller.extend({
appName:'Ember Twiddle'
});
<h1>Welcome to {{appName}}</h1>
{{some-component}}
{{#if someCondition}}
{{sub-component}}
{{else}}
{{sub-component}}
{{/if}}
{
"version": "0.4.7",
"dependencies": {
"jquery": "https://cdnjs.cloudflare.com/ajax/libs/jquery/1.11.3/jquery.js",
"ember": "https://cdnjs.cloudflare.com/ajax/libs/ember.js/1.13.6/ember.js",
"ember-data": "https://cdnjs.cloudflare.com/ajax/libs/ember-data.js/1.13.7/ember-data.js",
"ember-template-compiler": "https://cdnjs.cloudflare.com/ajax/libs/ember.js/1.13.6/ember-template-compiler.js"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment