Как выбрать случайное изображение из файлов в каталоге, используя Typoscript? - PullRequest
4 голосов
/ 22 февраля 2012

Я использую Typo3 4.5.3, и у меня есть файлы изображений в каталоге, из которого я хочу произвольно выбрать один для отображения на текущей странице, но я не могу понять, что опечатка имеет право сделать listnum = rand Работа. Вот мой шаблон расширения:

# Pick a random image to display
temp.banner = IMAGE
temp.banner {
  file {
    height = 165
    width = 954
    import {
      filelist = {$templatePathPrefix}images/banners | jpg,jpeg,png,gif | name | | 1
      listNum = rand
    }
  }
  params = class="bannerPic"
}

Если я изменяю настройку listnum на 0, 1 и т. Д., Она вставляет соответствующий img HTML в страницу. Установка 'last' также работает, но rand всегда вставляет первое изображение независимо от того, сколько раз я обновляюсь. Поскольку я могу выбирать конкретные изображения (0, 1, ...), я знаю, что общие настройки работают, но не случайный выбор.

Я видел TS для различных других применений rand, которые обертывают внешний объект в объект COA_INT, но у меня это тоже не сработало. Я что-то упустил о том, где разместить listNum = rand? Я довольно новичок в Typo3, поэтому многие из них все еще довольно непрозрачны для меня на данный момент (или это видно?). Спасибо за любую информацию, которую вы можете предоставить.

Ответы [ 3 ]

2 голосов
/ 22 февраля 2012

mak_stdwrapextended расширение добавляет возможность использовать rand с listNum.

Хорошо работает на 4.5.

1 голос
/ 14 мая 2013

только typo3 V4.6 и выше имеет listNum = rand в ядре, см. http://forge.typo3.org/issues/16180

для typo3 V4.5 вы должны расширить tslib / the class.tslib_content.php

добавить это в localconf.php:

$TYPO3_CONF_VARS['FE']['XCLASS']['tslib/class.tslib_content.php'] = PATH_site.'fileadmin/template/class.ux_tslib_content.php';

и добавьте этот код в class.ux_tslib_content.php:

<?php
/***************************************************************
*  Copyright notice
*
*  (c) 1999-2008 Kasper Skaarhoj (kasperYYYY@typo3.com)
*  All rights reserved
*
*  This script is part of the TYPO3 project. The TYPO3 project is
*  free software; you can redistribute it and/or modify
*  it under the terms of the GNU General Public License as published by
*  the Free Software Foundation; either version 2 of the License, or
*  (at your option) any later version.
*
*  The GNU General Public License can be found at
*  http://www.gnu.org/copyleft/gpl.html.
*  A copy is found in the textfile GPL.txt and important notices to the license
*  from the author is found in LICENSE.txt distributed with these scripts.
*
*
*  This script is distributed in the hope that it will be useful,
*  but WITHOUT ANY WARRANTY; without even the implied warranty of
*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
*  GNU General Public License for more details.
*
*  This copyright notice MUST APPEAR in all copies of the script!
***************************************************************/
/**
 * Contains classes for Content Rendering based on TypoScript Template configuration
 *
 * $Id: class.tslib_content.php 4254 2008-09-27 13:35:44Z dmitry $
 * Revised for TYPO3 3.6 June/2003 by Kasper Skaarhoj
 * XHTML compliant
 *
 * class tslib_cObj         :       All main TypoScript features, rendering of content objects (cObjects). This class is the backbone of TypoScript Template rendering.
 *
 * @author  Kasper Skaarhoj <kasperYYYY@typo3.com>
 */

/**
 * This class contains all main TypoScript features.
 * This includes the rendering of TypoScript content objects (cObjects).
 * Is the backbone of TypoScript Template rendering.
 *
 * There are lots of functions you can use from your include-scripts.
 * The class "tslib_cObj" is normally instantiated and referred to as "cObj".
 * When you call your own PHP-code typically through a USER or USER_INT cObject then it is this class that instantiates the object and calls the main method. Before it does so it will set (if you are using classes) a reference to itself in the internal variable "cObj" of the object. Thus you can access all functions and data from this class by $this->cObj->... from within you classes written to be USER or USER_INT content objects.
 *
 * @author  Kasper Skaarhoj <kasperYYYY@typo3.com>
 * @package TYPO3
 * @subpackage tslib
 * @link http://typo3.org/doc.0.html?&tx_extrepmgm_pi1[extUid]=270&cHash=4ad9d7acb4
 */
class ux_tslib_cObj extends tslib_cObj{


    /**
     * Exploding a string by the $char value (if integer its an ASCII value) and returning index $listNum
     *
     * @param   string      String to explode
     * @param   string      Index-number. You can place the word "last" in it and it will be substituted with the pointer to the last value. You can use math operators like "+-/*" (passed to calc())
     * @param   string      Either a string used to explode the content string or an integer value which will then be changed into a character, eg. "10" for a linebreak char.
     * @return  string
     */
    function listNum($content,$listNum,$char) {
        $char = $char ? $char : ',';
        if (t3lib_div::testInt($char))  {
            $char = chr($char);
        }
        $temp = explode($char,$content);
        $last = ''.(count($temp)-1);
        if($listNum === 'rand'){ $listNum = rand(0,count($temp)-1);} //taywa added: rand feature!
        $index=$this->calc(str_ireplace('last',$last,$listNum));
        return $temp[$index];
    }

}


?>
1 голос
/ 23 февраля 2012

Я бы не советовал вам делать случайный выбор через TypoScript.Так как вам нужно случайное изображение каждый раз, когда вы загружаете страницу, ваш случайный элемент должен быть элементом USER_INT или COA_INT и поэтому не может быть кэширован.

Простое решение для этого - сделать это через JavaScript.Вы определяете изображение по умолчанию, если JavaScript не доступен на клиенте, и JavaScript, который выбирает изображение случайным образом.С этим решением вы получаете случайное изображение каждый раз, и ваш контент полностью кэшируется.

Следующий код TypoScript может дать вам некоторое вдохновение для этого.Он в основном считывает Image-Elements из граничного столбца и генерирует JavaScript для их случайного вывода.Также изображения являются связанными.

lib.teaser = COA
lib.teaser.10 = CONTENT
lib.teaser.10 < styles.content.getBorder
lib.teaser.10 {
    slide = -1
    table=tt_content
    select{
        begin = 0
        max = 1
        #language
        languageField=sys_language_uid
        #from wich column
        where=colPos=3
    }
    wrap=<div class="teaserimage">|</div>

    renderObj=COA

    #image with gallery function
    renderObj.10 = COA
    renderObj.10 {
        stdWrap.required=1
        # get image
        10 = IMAGE
        10 {
            #if not empty
            required=1
            file.import=uploads/pics/
            file.import.field=image
            #file.width=266
            #file.height=180
            file.import.listNum = 0 
            stdWrap.insertData=1
            params = id="imgbig_{TSFE:currentRecord}"
            imageLinkWrap < tt_content.image.20.1.imageLinkWrap
            imageLinkWrap.typolink.ATagParams = id="link_imgbig_{TSFE:currentRecord}"
            imageLinkWrap.typolink.ATagParams.stdWrap.insertData=1
        }

        # standard image configuration from tt_content
        10.altText < tt_content.image.20.1.altText
        10.titleText < tt_content.image.20.1.titleText
        10.longdescURL < tt_content.image.20.1.longdescURL

        # random function for gallery images
        30 = COA
        30 {
            stdWrap.required=1
            stdWrap.dataWrap(
            <script type="text/javascript">
            /* <![CDATA[ */
            var imgArray = new Array(|);
            var randnum = Math.round(Math.random()*(imgArray.length-1));
            document.getElementById('imgbig_{TSFE:currentRecord}').src ='uploads/pics/' + imgArray[randnum];
            /* ]]> */
            </script>
            )

            # first gallery image
            10 = TEXT
            10.field = image
            10.listNum.splitChar=,
            10.listNum=0
            10.if.isTrue.field=image
            10.if.isTrue.listNum=1
            10.if.isTrue.listNum.splitChar=,
            10.dataWrap = "|"


            # other gallery images  
            20 = TEXT
            20.field = image
            20.split {
                token = ,
                cObjNum = 1
                1 = COA
                1.if.isPositive.data = TSFE:register|SPLIT_COUNT
                1 {
                    10 = TEXT
                    10.data = current:1
                    10.dataWrap = ,"|"
                }
            }
        }
        # random function for gallery links
        40 = COA
        40 {
            stdWrap.required=1
            stdWrap.dataWrap(
            <script type="text/javascript">
            /* <![CDATA[ */
            //var imgLinkArray = new Array(randnum);
            var imgLinkArray = new Array(|);
            if(document.getElementById('link_imgbig_{TSFE:currentRecord}')) document.getElementById('link_imgbig_{TSFE:currentRecord}').href = imgLinkArray[randnum];
            /* ]]> */
            </script>
            )

            # first gallery link            
            10 = TEXT
            10.field = image_link
            10.listNum.splitChar=,
            10.listNum=0
            10.dataWrap = "|"
            10.typolink.parameter.field = image_link
            10.typolink.returnLast = url

            # other gallery links   
            20 = TEXT
            20.field = image_link
            20.split {
                token = ,
                cObjNum = 1
                1 = COA
                1.if.isPositive.data = TSFE:register|SPLIT_COUNT
                1 {
                    10 = TEXT
                    10.data = current:1
                    10.dataWrap = ,"|"
                    10.typolink.parameter.data = current:1
                    10.typolink.returnLast = url
                }
            }
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...