Plone学习5——behaviors的创建与应用
目的
为了能够在web上给任意一个对象添加一个url字段,所以需要创建一个behavior——social
参考链接
步骤
1,创建目录和相关文件并注册
在ploneconf/site下面创建一个目录——behaviors,并在相应的configure.zcml里注册该目录
<include package=".behaviors" />
并在behaviors下创建__init__.py和configure.zcml文件
2,编辑文件configure.zcml
<configure
xmlns="http://namespaces.zope.org/zope"
xmlns:plone="http://namespaces.plone.org/plone"
i18n_domain="ploneconf.site">
<plone:behavior
title="Social Behavior"
name="ploneconf.social"
description="Adds a link to lanyrd"
provides=".social.ISocial"
/>
</configure>
字段分析:
- plone:behavior为固定语法
- title:为该behavior的名字
- name:为该behavior被引用的名称
- description:这个不用说,当然是描述啦
- provides:与其他的配置里的class用法相近,表示用哪个python文件/类去处理
3,编辑social.py文件
# -*- coding: utf-8 -*-
from plone.autoform.interfaces import IFormFieldProvider
from plone.supermodel import directives
from plone.supermodel import model
from zope import schema
from zope.interface import provider
@provider(IFormFieldProvider)
class ISocial(model.Schema):
directives.fieldset(
'social',
label=u'Social',
fields=('lanyrd',),
)
lanyrd = schema.URI(
title=u"Lanyrd link",
description=u"Add URL",
required=False,
)
这个代码就是给某个content type添加一个url字段
4,应用该behavior于talk类型
在ploneconf/site/profiles/default/types/talk.xml里添加一句(第三句)
<property name="behaviors">
<element value="plone.dublincore"/>
<element value="plone.namefromtitle"/>
<element value="ploneconf.social"/> # 就是这一句,上面的是已经存在的
</property>
- 这里就用到了注册social——behavior的name字段,plone是靠这个字段来获取该behavior的
- 注意要加在name="behaviors"的标签下面
- 忘了说了,talk.xml是根据plone training文档之前的训练部分自定义的一个content type,我们拿它来做实验
5,检查web上的behavior是否应用成功
首先当然是重启plone,这个不必多说。
我们可以在127.0.0.1:8080/Plone/dexterity-types/talk/@@behaviors上看到
Social Behavior 这里打上勾勾了。
没错!这里显示的就是之前注册时的title字段。
最后,我们打开一个talk内容的文档,编辑它,然后在behavior一栏下可以看到:
成功显示了behavior!