- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 ember cli 生成我的项目结构。当我使用 Mixin 和模型扩展 Route 类时。这些模型不再显示在我的商店中。
controllers/application.js::(ActiveclasscontrollerMixin 只是用来提供应用程序级别的属性,用于确定哪个类属性是事件的 - 我提供这个只是为了引用它其他的 mixin ActiveclassrouteMixin.js 与路由的模型 Hook 一起使用时会导致问题。)
import Ember from 'ember';
import ActiveclasscontrollerMixin from 'embercliapp/mixins/activeclasscontroller';
export default Ember.Controller.extend(ActiveclasscontrollerMixin);
controllers/posts.js
import Ember from 'ember';
var PostsController = Ember.ArrayController.extend();
export default PostsController;
template/posts.hbs(此模板在 routes/posts.js 时工作正常,仅在扩展 Ember.Route 对象时覆盖模型并显示所有 2 个帖子)
<div class="container-fluid">
<div class="row">
<div class="col-md-3">
<table class='table'>
<thead>
<tr><th>Recent Posts</th></tr>
</thead>
<tbody>
{{#each model}}
<tr>
<td>
{{#link-to 'post' this}}{{title}} <small class='muted'>by {{author.name}}</small>{{/link-to}}
</td>
</tr>
{{/each}}
</tbody>
</table>
</div>
<div class="span9">
{{outlet}}
</div>
</div>
</div>
mixins/ActiveclasscontrollerMixin.js -(仅在/controllers/application.js 中使用)
import Ember from 'ember';
export default Ember.Mixin.create({
isHome: '',
isPosts: '',
isAbout: '',
sayAlert: function(sayAlert){
alert(sayAlert);
},
setActiveClass: function(routeName) {
//alert('called setActiveClass:' + routeName);
if ((routeName === 'isHome') || (routeName === 'application') || (routeName === 'index')) {
this.set('isHome', 'active');
this.set('isPosts', '');
this.set('isAbout', '');
}
if (routeName === 'isPosts' || (routeName === 'posts')) {
this.set('isPosts', 'active');
this.set('isHome', '');
this.set('isAbout', '');
}
if (routeName === 'isAbout' || (routeName === 'about')) {
this.set('isAbout', 'active');
this.set('isPosts', '');
this.set('isHome', '');
}
},
actions: {
clickedAction: function(routeName) {
this.setActiveClass(routeName);
}
}
});
mixins/ActiveclassrouteMixin.js
import Ember from 'ember';
export default Ember.Mixin.create({
setupController: function(controller) {
this._super(controller);
var routeName = this.get('routeName');
this.controllerFor('application').setActiveClass(routeName);
}
});
routes/posts.js
import Ember from 'ember';
import ActiveclassrouteMixin from 'embercliapp/mixins/activeclassroute';
var posts = [{
id: '1',
title: "Rails is Omakase",
author: {
name: "d2h"
},
date: new Date('12-27-2012'),
excerpt: "There are lots of à la carte software environments in this world. Places where in order to eat, you must first carefully look over the menu of options to order exactly what you want.",
body: "I want this for my ORM, I want that for my template language, and let's finish it off with this routing library. Of course, you're going to have to know what you want, and you'll rarely have your horizon expanded if you always order the same thing, but there it is. It's a very popular way of consuming software.\n\nRails is not that. Rails is omakase."
}, {
id: '2',
title: "The Parley Letter",
author: {
name: "d2h"
},
date: new Date('12-24-2012'),
excerpt: "My [appearance on the Ruby Rogues podcast](http://rubyrogues.com/056-rr-david-heinemeier-hansson/) recently came up for discussion again on the private Parley mailing list.",
body: "A long list of topics were raised and I took a time to ramble at large about all of them at once. Apologies for not taking the time to be more succinct, but at least each topic has a header so you can skip stuff you don't care about.\n\n### Maintainability\n\nIt's simply not true to say that I don't care about maintainability. I still work on the oldest Rails app in the world."
}];
export default Ember.Route.extend({
model: function() {
return posts;
}
});
在上述情况下,一切都按预期进行。但是,如果我在扩展路线时添加使用混合(ActiveclassrouteMixin)和模型,模型将停止在导出中显示:
export default Ember.Route.extend(ActiveclassrouteMixin,{
model: function() {
return posts;
}
});
commond cli 构建/服务过程或 chrome javascript 控制台中没有错误。
最佳答案
我会将所需的代码提炼为:
controller.js
setupController: function(controller, models) {
this._super(controller, models); // insure mixin.setupController() called
controller.setProperties( models );
}
mixin.js
setupController: function(controller, models) {
this._super(controller, models); // Allow others to be called
}
现在您可以在 mixin 中设置模型的属性!
关于javascript - Ember 路由混合模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26860430/
我的 Angular 应用程序中有以下代码。 app.config(function($routeProvider, $locationProvider) { $locationProvider
这就是我在 Backbone 中进行路由的方式,在决定调用哪个外部模板之前,首先获取路由及其参数。我觉得这很灵活。 var Router = Backbone.Router.extend({
我是 MEAN 堆栈领域的新手,我对 Angular 路线有一些疑问。为什么我应该在客户端重新创建后端已经用express.js创建的路由,有什么好处?这是 Angular.js 工作的唯一方式吗?我
我可以设置一条从根级 URL 进行映射的路由吗? http://localhost:49658/ 我使用的是 VS2010 内置 Web 服务器。 尝试使用空白或单斜杠 URL 字符串设置路由不起作用
我有一个现有的应用程序 Rails 3.2.17和 Angular js。我想在现有应用程序中包含 Activeadmin。 我遵循了 active-admin post from ryan bate
我正在关注 this Angular 中的路由教程,它就是行不通。当我使用“comp”选择器放置它的 HTML 代码时,它可以工作,但是当我尝试使用路由器 socket 对其进行路由时,它只显示来自
多个路由通过路由器进行管理。 前端路由的概念和原理 (编程中的) 路由 (router)就是一组 key-value 对应关系,分为:后端路由和前端路由 后端路由
服务器需要根据不同的URL或请求来执行不一样的操作,我们可以通过路由来实现这个步骤。 第一步我们需要先解析出请求URL的路径,我们引入url模块。 我们来给onRequest()函数加上一些逻辑
我正在为 Angular 6 应用程序设置路由,我想要一条可以匹配可变数量的段的路由。目前我有一个看起来像这样的路由配置: const routes: Routes = [ { path: '',
用户将点击电子邮件中的链接,如下所示: do-something/doSomething?thing=XXXXXXXXXXX 如何在路由器中定义路由并订阅获取参数? 目前在我的路由器中: {
我有一个具有以下结构的 Angular (4) 应用程序: app.module bi.module auth.module 路由应该是: / -> redirect to /home /
我正在使用 WCF 4 路由服务,并且需要以编程方式配置服务(而不是通过配置)。我见过的这样做的例子很少见,创建一个 MessageFilterTable 如下: var fi
我需要创建一个“路由”服务。我正在尝试使用 .Net 的 System.ServiceModel.Routing.IRequestReplyRouter我可以让它只在 HTTP 模式下工作,而不是在
例如,链接: /shop/phones/brend/apple/display/retina/color/red 在哪里: phones - category alias brend -
非常基本的问题,我很惊讶我找不到答案。我刚刚开始研究 django 并进行了开箱即用的安装。创建了一个项目并创建了一个应用程序。 urls.py 的默认内容很简单: urlpatterns = [
我已经实现了 WCF 路由服务;我还希望该服务(或类似的 WCF 服务)以规定的和统一的(与内容无关的)方式转换有效负载。例如,有效负载将始终采用 Foo 的形式。我想把它作为Bar在所有情况下。我很
我想使用 $locationProvider.html5Mode(true); 在 angularJs 中删除 # 哈希;但这导致所有 URL 都通过 angularJs 进行路由。我如何设置它以便只
我要听导航开始事件并判断其是否url属性是 /logout . 如果是这样,路由器应该停止触发连续事件,例如 路线已识别 , GuardsCheckStart , ChildActivationSta
有人可以解释我如何使用参数路由到 URL 吗? 例如id 喜欢点击产品并通过Id打开产品的更多信息。 我的路由到目前为止... angular.module('shop', ["cus
我目前正在 Angular: 7.2.14 上构建,想看看是否有人可以解释如何使用路由保护、共享服务或其他方式等重定向查询参数。 我试图解决的问题要求查询参数从根 Uri 路径传入,然后将路由重定向到
我是一名优秀的程序员,十分优秀!