跳转到主要内容

为Zope3提供的简单菜单系统

项目描述

此软件包提供了一种基于视图的简单菜单实现。

简单菜单

当前,z3c.menu.simple 软件包提供了一种简单菜单实现,允许您基于内容提供者和视图实现简单的菜单。

目前,此软件包中包含一些 SimpleMenuItem 菜单项实现和带有标签/标签项和动作/动作项的标签菜单。

让我们看看这意味着什么。

上下文菜单

>>> from zope.viewlet.interfaces import IViewlet
>>> from zope.viewlet.interfaces import IViewletManager

让我们创建一个菜单,这意味着我们定义一个视图管理器接口

>>> class IMenu(IViewletManager):
...     """Menu viewlet manager."""

您现在可以使用此接口创建一个视图管理器

>>> from zope.viewlet import manager
>>> Menu = manager.ViewletManager('left', IMenu)

现在我们必须定义一个上下文

>>> import zope.interface
>>> from zope.app.container import contained
>>> from zope.app.container.interfaces import IContained
>>> class Content(contained.Contained):
...     zope.interface.implements(IContained)
>>> root['content'] = Content()
>>> content = root['content']
>>> from zope.publisher.browser import TestRequest
>>> request = TestRequest()
>>> from zope.publisher.interfaces.browser import IBrowserView
>>> class View(contained.Contained):
...     zope.interface.implements(IBrowserView)
...     def __init__(self, context, request):
...         self.__parent__ = context
...         self.context = context
...         self.request = request
>>> view = View(content, request)
>>> menu = Menu(content, request, view)

所以最初没有菜单被渲染

>>> menu.update()
>>> menu.render()
u''

但现在我们为 IMenu 注册一个上下文菜单项

>>> import zope.component
>>> from zope.publisher.interfaces.browser import IDefaultBrowserLayer
>>> from z3c.menu.simple.menu import ContextMenuItem
>>> class MyLocalLink(ContextMenuItem):
...
...     __name__ = u'MyLocalLink'
...     urlEndings = 'myLocal.html'
...     viewURL = 'myLocal.html'
>>> # Create a security checker for viewlets.
>>> from zope.security.checker import NamesChecker, defineChecker
>>> viewletChecker = NamesChecker(('update', 'render'))
>>> defineChecker(MyLocalLink, viewletChecker)
>>> zope.component.provideAdapter(
...     MyLocalLink,
...     (zope.interface.Interface, IDefaultBrowserLayer,
...     IBrowserView, IMenu),
...     IViewlet, name='MyLocalLink')

现在看看如果使用 IMenu 视图管理器我们会得到什么

>>> menu.update()
>>> print menu.render()
<a href="http://127.0.0.1/content/myLocal.html"
   class="inactive-menu-item">MyLocalLink</a>

标签菜单

现在我们创建一个名为 MasterMenu 的标签菜单

>>> class IMasterMenu(IViewletManager):
...     """Master menu viewlet manager."""

让我们使用此接口和 TabMenu 作为基类创建一个视图管理器

>>> from z3c.menu.simple.menu import TabMenu
>>> MasterMenu = manager.ViewletManager('masterMenu', IMasterMenu,
...                                     bases=(TabMenu,))

我们使用与之前相同的上下文、请求和视图

>>> masterMenu = MasterMenu(content, request, view)

所以最初没有菜单被渲染

>>> masterMenu.update()
>>> masterMenu.render()
u''

现在我们注册一个也是视图管理器的菜单标签

>>> from zope.browserpage import viewpagetemplatefile
>>> from z3c.menu.simple import ITab
>>> from z3c.menu.simple.menu import Tab
>>> class MyTabs(Tab):
...     template = viewpagetemplatefile.ViewPageTemplateFile('tab.pt')
>>> myTabs = MyTabs(content, request, view)

在这里,最初也没有标签被渲染

>>> myTabs.update()
>>> myTabs.render()
u''

现在我们注册一个也是视图管理器的菜单动作

>>> from z3c.menu.simple import IAction
>>> from z3c.menu.simple.menu import Action
>>> class MyActions(Action):
...     template = viewpagetemplatefile.ViewPageTemplateFile('action.pt')
>>> myActions = MyActions(content, request, view)

在这里,最初也没有标签被渲染

>>> myActions.update()
>>> myActions.render()
u''

在设置 TabMenuTabAction 视图管理器之后,我们开始注册标签菜单项

>>> from z3c.menu.simple.menu import TabItem
>>> class MyTab(TabItem):
...
...     __name__ = u'MyTab'
...     url = 'myTab.html'
...     selectedViewNames = ['myTab.html']
>>> tabChecker = NamesChecker(('update', 'render', 'css', 'selected'))
>>> defineChecker(MyTab, tabChecker)
>>> zope.component.provideAdapter(
...     MyTab,
...     (zope.interface.Interface, IDefaultBrowserLayer,
...     IBrowserView, ITab),
...     IViewlet, name='MyTab')

现在看看如果渲染标签视图管理器我们会得到什么

>>> myTabs.update()
>>> print myTabs.render()
<div class="tabMenu">
  <span class="inactive-menu-item">
  <a href="myTab.html">MyTab</a>
</span>
</div>

在展示了如何使用标签菜单项之后,我们将注册菜单动作项。

>>> from z3c.menu.simple.menu import ActionItem
>>> class MyAction(ActionItem):
...
...     __name__ = u'MyAction'
...     title = 'myAction'
>>> actionChecker = NamesChecker(('update', 'render', 'title'))
>>> defineChecker(MyAction, actionChecker)
>>> zope.component.provideAdapter(
...     MyAction,
...     (zope.interface.Interface, IDefaultBrowserLayer,
...     IBrowserView, IAction),
...     IViewlet, name='MyAction')

现在看看如果使用动作视图管理器我们会得到什么

>>> myActions.update()
>>> print myActions.render()
<div class="actionMenuWrapper">
  <ul class="actionMenu">
    <li class="inactive-menu-item">
      <a href="">
        <div>myAction</div>
      </a>
    </li>
  </ul>
</div>
<div class="clearActionMenu" />

变更记录

0.6.0 (2010-07-14)

  • 根据需要,依赖 zope.browserpage 而不是 zope.app.pagetemplate,因为必要的代码已经移动到了那里。

  • 不再使用已弃用的 zope.testing.doc[unit]test,改用 Python 的 doctest

0.5.2 (2009-11-19)

  • 移除了 zope.app.zapi 依赖。

0.5.1 (2008-01-25)

  • 错误:更新了元数据和文档。

0.5.0 (2008-01-21)

  • 初始发布。

项目详情


下载文件

下载适合您平台的文件。如果您不确定选择哪个,请了解更多关于 安装包 的信息。

源代码分发

z3c.menu.simple-0.6.0.tar.gz (9.0 kB 查看哈希值)

源代码

支持