Skip to main content

dynamic key in JSON file (used by backbone.js models for example…)



I am trying to create a backbone.js model with dynamic keys but can't seem to get it done right.





Here's my model:







window.MyModel = Backbone.Model.extend({

myDynamicVar : "country",

urlRoot: "api/myModel",

defaults: {

"id": null,

this.myDynamicVar : "USA",

"country": {

"route":"test/test/test",

"class":".usa2",

"txt":"USA 2"

},

"region": "California",

"year": "",

"description": "",

"picture": ""

}

});







Here I am trying to have myDynamicVar replaced by its content in my model. Any thought how I could get this done? Thanks in advance, Jimmy


Comments

  1. You cannot use a variable in defining the object key. You can try something like this.

    window.MyModel = Backbone.Model.extend({
    myDynamicVar : "country",
    urlRoot: "api/myModel",
    defaults: {
    "id": null,
    "country": {
    "route":"test/test/test",
    "class":".usa2",
    "txt":"USA 2"
    },
    "region": "California",
    "year": "",
    "description": "",
    "picture": ""
    }
    });

    window.MyModel.defaults[this.myDynamicVar] = "USA";

    ReplyDelete
  2. You won't be able to do that directly; the left side of the ":" in an object literal must be a constant. What you can do is this:

    window.MyModel = Backbone.Model.extend({
    myDynamicVar : "country",
    urlRoot: "api/myModel",
    defaults: function(fieldName) {
    var value = {
    "id": null,
    "country": {
    "route":"test/test/test",
    "class":".usa2",
    "txt":"USA 2"
    },
    "region": "California",
    "year": "",
    "description": "",
    "picture": ""
    };
    value[fieldName] = "USA";
    return value;
    }(this.myDynamicVar)
    });


    edit — ah, I just noticed that "myDynamicVar" itself is part of the outer object. There's no way to refer to it with this in such a way, so if that's what you're trying to do the code would be different:

    window.MyModel = Backbone.Model.extend(function() {
    var value = {
    myDynamicVar : "country",
    urlRoot: "api/myModel",
    defaults: {
    "id": null,
    "country": {
    "route":"test/test/test",
    "class":".usa2",
    "txt":"USA 2"
    },
    "region": "California",
    "year": "",
    "description": "",
    "picture": ""
    }
    };

    value.defaults.[value.myDynamicVar] = "USA";
    return value;
    }());


    If you want myDynamicVar itself to be dynamic, then you could pass it in as a parameter:

    window.MyModel = Backbone.Model.extend(function(whichProperty) {
    var value = {
    myDynamicVar : "country",
    urlRoot: "api/myModel",
    defaults: {
    "id": null,
    "country": {
    "route":"test/test/test",
    "class":".usa2",
    "txt":"USA 2"
    },
    "region": "California",
    "year": "",
    "description": "",
    "picture": ""
    }
    };

    value.defaults.[value[whichProperty]] = "USA";
    return value;
    }("myDynamicVar"));

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...

Is it possible to have IF statement in an Echo statement in PHP

Thanks in advance. I did look at the other questions/answers that were similar and didn't find exactly what I was looking for. I'm trying to do this, am I on the right path? echo " <div id='tabs-".$match."'> <textarea id='".$match."' name='".$match."'>". if ($COLUMN_NAME === $match) { echo $FIELD_WITH_COLUMN_NAME; } else { } ."</textarea> <script type='text/javascript'> CKEDITOR.replace( '".$match."' ); </script> </div>"; I am getting the following error message in the browser: Parse error: syntax error, unexpected T_IF Please let me know if this is the right way to go about nesting an IF statement inside an echo. Thank you.