Knockout.js 为 location.href 获取对象 属性
Knockout.js get property of an object for location.href
我最近发现了 Knockout,我正在努力获取 foreach 中对象的属性:
这是我的代码:
<table class="table">
<thead>
<tr>
<th>Name</th>
<th>Created By</th>
</tr>
</thead>
<tbody data-bind="foreach: assets">
<tr class="assets" data-bind="click: $parent.detailPage">
<td>
<span data-bind="text: FileName"></span>
</td>
<td>
<span data-bind="text: CreatedBy"></span>
</td>
</tr>
</tbody>
和我的脚本:
<script>
function ViewModel(assets) {
var self = this;
self.assets = assets;
self.detailPage = function (asset) {
location.href = '@Url.Action("Details", "Assets")/' + asset.Id;
};
};
var jsonModel = new ViewModel(@Html.Raw(Json.Encode(Model)));
var viewModel = ko.mapping.fromJS(jsonModel);
ko.applyBindings(viewModel);
在我的资产中,我有一个 ID,我想使用我单击的对象的 ID 打开我的视图。
但是当我执行它时,url 变成:http://localhost:62677/Assets/Details/[object Object]
任何正确执行此操作的想法?
谢谢!
看起来 asset.Id 是一个对象。
尝试调查为什么它是对象而不是某个数字或字符串。
假设 asset.Id 是可观察到的淘汰赛,试试这个
self.detailPage = function (asset) {
location.href = '@Url.Action("Details", "Assets")/' + asset.Id();
};
我最近发现了 Knockout,我正在努力获取 foreach 中对象的属性:
这是我的代码:
<table class="table">
<thead>
<tr>
<th>Name</th>
<th>Created By</th>
</tr>
</thead>
<tbody data-bind="foreach: assets">
<tr class="assets" data-bind="click: $parent.detailPage">
<td>
<span data-bind="text: FileName"></span>
</td>
<td>
<span data-bind="text: CreatedBy"></span>
</td>
</tr>
</tbody>
和我的脚本:
<script>
function ViewModel(assets) {
var self = this;
self.assets = assets;
self.detailPage = function (asset) {
location.href = '@Url.Action("Details", "Assets")/' + asset.Id;
};
};
var jsonModel = new ViewModel(@Html.Raw(Json.Encode(Model)));
var viewModel = ko.mapping.fromJS(jsonModel);
ko.applyBindings(viewModel);
在我的资产中,我有一个 ID,我想使用我单击的对象的 ID 打开我的视图。
但是当我执行它时,url 变成:http://localhost:62677/Assets/Details/[object Object]
任何正确执行此操作的想法?
谢谢!
看起来 asset.Id 是一个对象。 尝试调查为什么它是对象而不是某个数字或字符串。
假设 asset.Id 是可观察到的淘汰赛,试试这个
self.detailPage = function (asset) {
location.href = '@Url.Action("Details", "Assets")/' + asset.Id();
};