betheme主题实现部分内容全宽设定
2020年9月28日
极简主义网页的设计方案和实践办法
2020年10月9日

betheme自带的页面编辑器功能虽然很丰富,不过国外的网站排版有时候在国内就吧是非常实用了,遇到一些特殊的功能还是需要修改一下,分享一个尝用到的功能,就是产品列表页小工具,当然了这个除了小工具使用其他办法也能实现。

 

<?php
/**
 
 */

if (! class_exists('Mfn_Widget_Portfolio')) {
  class Mfn_Widget_Portfolio extends WP_Widget
  {

    /**
     * 构造函数
     */

    public function __construct()
    {
      $widget_ops = array(
        'classname' => 'widget_mfn_recent_portfolio',
        'description' => __('显示产品分级列表.', 'mfn-opts')
      );

      parent::__construct('widget_mfn_recent_portfolio', __('Muffin产品列表', 'mfn-opts'), $widget_ops);

      $this->alt_option_name = 'widget_mfn_recent_portfolio';
    }

    /**
     * 输出此窗口小部件的HTML。
     */

    public function widget($args, $instance)
    {
      if (! isset($args['widget_id'])) {
        $args['widget_id'] = null;
      }
      extract($args, EXTR_SKIP);

      echo wp_kses_post($before_widget);
      $portfolioID =  get_queried_object_id();  
           
      $aCategories = array();    
      $terms = get_the_terms(get_the_ID(), 'portfolio-types');
      if (is_array($terms)) {
        foreach ($terms as $term) {
          $aCategories[]    = $term->term_id;
        }
      }
              $itemAll = mfn_opts_get('translate') ? mfn_opts_get('translate-item-all', 'All') : __('All', 'betheme');//mfn_opts_get('translate') ? mfn_opts_get('translate-all', 'Show all') : __('Show all', 'betheme')
      echo '<div class="widget_mfn_menu menu-menu-container">
                    <ul id="menu-menu-4" class="menu submenus-hover submenu-active">';

        if( $portfolio_categories = get_terms('portfolio-types') ){
                  
                      $portfolio_page_id = mfn_opts_get('portfolio-page');
                   
                      $portfoliotermallclass = ($portfolioID == $portfolio_page_id) ? 'current_page_item' : '';
                      echo '<li class="menu-item menu-item-type-post_type menu-item-object-page '. $portfoliotermallclass .'"><a data-rel="*" href="'. esc_url(get_permalink(mfn_wpml_ID($portfolio_page_id))) .'">'. esc_html($itemAll) .'</a></li>';
          foreach( $portfolio_categories as $category ){
                          $portfoliotermclass = ($portfolioID == $category->term_id) ? 'current_page_item' : '';
                          $menuportfolioclass =  ($aCategories[0] == $category->term_id) ? 'current-menu-ancestor': '';
            echo '<li class="menu-item menu-item-type-post_type menu-item-object-page '. $menuportfolioclass .' '. $portfoliotermclass .' menu-item-has-children '. esc_attr($category->slug) .'"><a data-rel=".category-'. esc_attr($category->slug) .'" href="'. esc_url(get_term_link($category)) .'">'. esc_html($category->name) .'</a>';
                       
                        $typesargs = array(
              'tax_query' => array(
                array(
                  'taxonomy' => 'portfolio-types',
                  'field' => 'term_id',
                  'terms' => $category->term_id
                ),
              ),
            );
            $query_related_posts = new WP_Query($typesargs);
            if ($query_related_posts->have_posts()) {
                           echo '<ul class="sub-menu">';
                while ($query_related_posts->have_posts()) {
                  $query_related_posts->the_post();
                                    $portfolioclass = ($portfolioID == get_the_ID()) ? 'current-menu-item' : '';
                                    echo '<li class="menu-item menu-item-type-taxonomy menu-item-object-portfolio-types '.$portfolioclass. ' '. get_the_ID() .'"><a style="word-break: keep-all;white-space: nowrap;overflow: hidden;text-overflow:ellipsis;" href="'. esc_url(get_permalink()) .'">'. wp_kses(get_the_title(), mfn_allowed_html()) .'</a></li>';     
                } 
                          echo '</ul>';
            }
            wp_reset_postdata();
            echo '</li>';
          }
                }         
        echo '</ul></div>';
      echo wp_kses_post($after_widget);
    }

    
  }
}

 

betheme/functions/widgets文件夹内新建一个文件,随便命个名,把上面代码复制进去就可以了,然后去小工具把他拖到要用的位置。

然后看一下效果吧:

实现效果:

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注