宜兴通达竭诚为您服务。

通达科技 - 宜兴电脑维护及IT服务外包服务商

OWL 教程: TodoApp-12、过滤任务
  • 上传者: Administrator
  • 上传时间:2023年09月15日 08时27分28秒
摘要:
我们几乎完成了,我们可以添加/更新/删除任务。唯一缺少的功能是根据任务的完成状态显示任务的可能性。 我们需要在Root中跟踪过滤器的状态,然后根据它的值过滤可见任务。 class Root extends Component { static template = xml /* x ......
正文 相关文章 请喝咖啡

    我们几乎完成了,我们可以添加/更新/删除任务。唯一缺少的功能是根据任务的完成状态显示任务的可能性。我们需要在Root中跟踪过滤器的状态,然后根据它的值过滤可见任务。

    class Root extends Component {
      static template = xml /* xml */`
        <div class="todo-app">
          <input placeholder="Enter a new task" t-on-keyup="addTask" t-ref="add-input"/>
          <div class="task-list">
            <t t-foreach="displayedTasks" t-as="task" t-key="task.id">
              <Task task="task"/>
            </t>
          </div>
          <div class="task-panel" t-if="store.tasks.length">
            <div class="task-counter">
              <t t-esc="displayedTasks.length"/>
              <t t-if="displayedTasks.length lt store.tasks.length">
                  / <t t-esc="store.tasks.length"/>
              </t>
              task(s)
            </div>
            <div>
              <span t-foreach="['all', 'active', 'completed']"
                t-as="f" t-key="f"
                t-att-class="{active: filter.value===f}"
                t-on-click="() => this.setFilter(f)"
                t-esc="f"/>
            </div>
          </div>
        </div>`;
    
      setup() {
        ...
        this.filter = useState({ value: "all" });
      }
    
      get displayedTasks() {
        const tasks = this.store.tasks;
        switch (this.filter.value) {
          case "active": return tasks.filter(t => !t.isCompleted);
          case "completed": return tasks.filter(t => t.isCompleted);
          case "all": return tasks;
        }
      }
    
      setFilter(filter) {
        this.filter.value = filter;
      }
    }
    .task-panel {
      color: #0088ff;
      margin-top: 8px;
      font-size: 14px;
      display: flex;
    }
    
    .task-panel .task-counter {
      flex-grow: 1;
    }
    
    .task-panel span {
      padding: 5px;
      cursor: pointer;
    }
    
    .task-panel span.active {
      font-weight: bold;
    }

    注意,这里我们用对象语法动态地设置了过滤器的css类。

    本文章从网上收集,如有侵权请联系tderp@tderp.com删除
  • 微信扫一扫,一分也是爱:
  • 微信

服务原则及地区范围

宜兴通达网络科技有限公司,地处中国宜兴环科园内,是一家高新技术企业。公司在企业网络维护和企业信息化建设与咨询方面,有10多年经验。

我公司愿与客户一道,力求彻底解决客户问题!
我们不是在给企业提供“头痛医头、脚痛医脚”的暂时解决方案,而是在部署根本性安全与稳定服务!!
我们愿携手客户,建立企业IT规划;杜绝随意安装系统、软件等操作;力求共同维护有序、安全、稳定的网络办公环境!!!
IT服务,服务是根本,客户是上帝;我们提供快速响应、快速上门、快速排查,提供优质高效的服务!!!!

通达科技提供全国范围内的服务,服务形式包括远程协助、电话咨询、电子邮件咨询、传真咨询、问答平台的问题解决等。

宜兴地区提供上门服务:

  • 市区服务:宜城街道、城北街道(屺亭街道)、新街街道、新庄街道、环科园、渚桥开发区
  • 市郊服务:张渚镇、西渚镇、太华镇、徐舍镇、官林镇、杨巷镇、新建镇、和桥镇、高塍镇、万石镇、周铁镇、芳桥镇、丁蜀镇、湖父镇。
  • 联系电话:189-21-343434
  • 在线沟通: