- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经学习 ractive.js 几个星期了,我正在尝试在一个更大的网页中构建一个列出三个项目的功能。每个列表都有自己的标题和描述。每个列表都是一个组件(列表组件),具有自己的样式和 javascript(每个组件都是一个单独的 html)。我还有一个组件(描述组件),负责写出标题和描述,它位于一个单独的 html 文件中。我遇到的问题是“导入”或将该描述组件引入列表组件,因此主索引 html 文件中的输出是这样的:
<description title="Name">
<list-items/>
</description>
到目前为止,我研究了yield指令并尝试了一些示例,但这是一个在同一文档上使用两个组件的简单示例。我不确定这是否是正确的方法。这是描述组件 html 文件中的内容:
<p>{{title}}</p>
我尝试使用 ractive-load.js 并为每个列表组件文件加载描述组件 html,如其 github 上的此示例所示:
Ractive.load({
Foo: 'my-components/foo.html',
Bar: 'my-components/bar.html'
}).then( function ( components ) {
var foo = new components.Foo({
el: 'body',
data: { ... }
});
var bar = new components.Bar({
el: 'body',
data: { ... }
});
}).catch( handleError );
这似乎有点矫枉过正,我认为必须有更好的方法。我将如何解决这个问题?
最佳答案
Ractive 组件的加载与处理嵌套组件以及将生成的内容传递给组件没有直接关系。
Ractive.load
其工作原理是获取一个或多个 html 文件,然后将其解析为组件。从您的代码示例来看,您似乎已经使该部分正常工作。对于较大的应用程序,我通常使用构建工具插件来预捆绑所有 Ractive 组件,以便它们可以在一个文件中交付,甚至可以卷入我的主捆绑 js 中。
无论组件如何可用,它们都需要在使用组件(或 View 父级)或全局上注册:
Ractive.load({
Foo: 'my-components/foo.html',
Bar: 'my-components/bar.html'
}).then( function ( components ) {
Ractive.components.foo = components.Foo;
Ractive.components.bar = components.Bar;
// now create your actual top-level view instance(s)
}).catch( handleError );
在组件架构中,您可以创建组件树或灌木丛。我通常只有一个顶级 app
组件,但创建从 DOM 中不同位置开始的多个树当然是可行的。
为了简单起见,继续上面的示例,让我们创建一个通用的 ractive 实例,它使用我们注册的两个组件 Foo 和 Bar(注意我们使用分配给 Ractive.components
的属性名称):
const ractive = new Ractive({
el: document.body,
sayHello() {
alert('hello from main Ractive instance');
},
template: `
<h1>my kewl app</h1>
<foo>
<h3 on-click="sayHello()">hello world</h3>
<bar bizz="{{buzz}}"></bar>
</foo>
`
});
在本例中,我们将一些内容(html 和 bar 组件)传递给 foo 组件,方法是将其包含为 <foo>
元素内容。
如何使用此内容取决于 foo
模板。有两种选择:
<div>
<h2>foo component template</h2>
{{>content}}
<p>some more stuff</p>
</div>
在此示例中,我们使用内置的部分“内容”来告诉模板将提供的内容放入 {{>content}}
中。投币口。在这种情况下,提供的内容像部分内容一样传递,任何指令都将应用于 foo
成分。因此,在此示例中,单击 h3 header 将尝试运行 foo.sayHello()
。当通过bizz
时数据发送至bar
组件,Ractive 将开始在 foo
中查找buzz
的组件.
通常,这不是您想要的。您希望发生的事情是让 parent 拥有这些指令。所以改为 foo
模板看起来像:
<div>
<h2>foo component template</h2>
{{yield}}
<p>some more stuff</p>
</div>
现在当 h3
点击后,它会调用主ractive.sayHello()
方法,因为内容被传递以由 foo 组件在 DOM 中呈现,但它仍然由传递的实例拥有。同样,Ractive 将开始查找 buzz
在主实例中,不是 foo
.
与 yield
您还可以命名要传递的多个部分:
<!-- "foo" template: -->
<div>
<header>{{yield header}}</header>
<section>
<div>something here</div>
<div>{{yield message}}</div>
</section>
</div>
<!-- using "foo": -->
<div>
<foo>
{{#partial header}}
<h2>This is the header to use</h2>
{{/partial}}
{{#partial message}}
<p>This is the message to use, with a bar component to boot</p>
<bar></bar>
{{/partial}}
</foo>
</div>
关于javascript - 当组件位于两个单独的文件中时,如何在 ractive.js 中将组件插入和嵌套在另一个组件中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38161347/
我正在使用 javascript 并有以下类: const Product = require('../models').Product class ProductService { cons
我正在开发一个简单的应用程序,宠物用户可以在其中创建关于他们宠物的板并在板上显示图片。 我正在尝试创建一个功能,用户可以点击他们的图板,将他们重定向到他们的图板,该图板将显示他们所有的宠物图片。 当我
我有这样的事情:循环遍历 ids,并对每个 ids 向服务器(同一域)发出 ajax 请求 (async:true) 并将接收到的数据附加到 DOM 元素。这不是一项艰巨的任务,它确实有效。示例代码:
我正在尝试使用 Pillow 在我的网络应用程序中添加用户可上传的图像。我创建了一个 Django Upload 模型并将其注册到 Admin 中。当我使用管理控制台添加照片后,我收到以下错误。最初该
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
说到 UINavigationBar 时我有点困惑。我以编程方式设置它,它的作用是将我的 viewController 向下推(因此在启动应用程序后看不到 Storyboard中看到的 View 底部
我有以下查询,它可以满足我的要求,并显示从出生日期转换而来的人们的年龄。但我现在想通过说大于或小于这些年龄来缩小结果范围,但我不知道该怎么做。 SELECT u.`id` as `user_id`
我有一个 ListView (不是 recyclerView),其中每一行都有一个按钮、几个 TextView 和一个 EditText。单击特定按钮(“editTremp”)后,我希望 EditTe
我的 cellAtIndexPath 中有一个查询。正如常见的那样,此查询从单元格行索引处的数组中获取对象。我想知道每次加载 tableView 时是否只有一个查询,还是将其算作每个 indexPat
我目前正在探索 http://www.ecovivo.be/rubriek/food 上使用的模板中的错误. 问题:访问该链接时,您会注意到右侧有一个带有内容的大型 float 图像。现在一切正常。但
我在 ViewController 之间通过引用传递特定模型的数组。 如果我更改数组中特定元素的任何值,它会在所有 ViewController 中很好地反射(reflect),但是当我从该数组中删除
svg 包含更多元素,其中之一是下拉选择器。我遇到的问题是选择器只能在其顶部边缘被点击,而不能在选择器的其他任何地方被点击。 选择器称为 yp-date-range-selector。在下一张图片中,
我的元素使用 20 行 20 列的 css 网格布局(每个单元格占屏幕的 5%)。其中一个页面有一个按钮。最初该页面包含在网格第 5-8 列和网格第 6-9 行中,按钮本身没有问题,但我需要将其居中放
我想使用 CSS Trick 使图像居中.但是如果图像大小是随机的(不固定的)怎么办。令人惊讶的是,我不想保持图像响应,我想在不改变其宽度或高度(实际像素)的情况下将图像置于中心。 下面是我的代码:
我正在尝试在网址之间进行路由。产品是一个类: from django.db import models from django.urls import reverse # Create your mo
我正在通过查看 Django 教程来制作网站。我收到一个错误: NoReverseMatch at /polls/ Reverse for 'index' with no arguments not
我一直在试用 Django 教程 Django Tutorial Page 3并遇到了这个错误 "TemplateDoesNotExist at /polls/ " . 我假设问题出在我的代码指向模板
我有一个应用程序,其中大部分图像资源都存储在单独的资源包中(这样做是有正当理由的)。这个资源包与主应用程序包一起添加到项目中,当我在 Interface Builder 中设计我的 NIB 时,所有这
我使用 Xcode 6.3.2 开发了一个 iPad 应用程序。我将我的应用程序提交到 App Store 进行审核,但由于崩溃而被拒绝。以下是来自 iTunes 的崩溃报告。 Incident Id
我正在使用以下内容来显示水平滚动条: CSS: div { width: 300px; overflow-x: scroll; } div::-webkit-scrollbar {
我是一名优秀的程序员,十分优秀!