D
D
Dmitry Korshunov2014-02-14 22:19:47
PHP
Dmitry Korshunov, 2014-02-14 22:19:47

PHP. Several options in switch case. What are the solutions?

Standard code example:

$format = 'png';

SWITCH ($format):
   case 'txt': // условие 1
      break;
   case 'jpg': case 'png': case 'gif':  // условие 2
      break;
   default: // условие по умолчанию
      break;
ENDSWITCH;

How do you get rid of this entry: case 'jpg': case 'png': case 'gif':
It's annoying that there are no options for writing case 'jpg', 'png', 'gif': or case ['jpg', 'png', 'gif']:

Answer the question

In order to leave comments, you need to log in

5 answer(s)
S
Sergey Sokolov, 2014-02-14
@dkorshunov55

switch ... casethat's just how it's written.
You can do something like this:

$format = 'png';

$ext = array(
    'text' => array(
        'txt' => TRUE,
    ),
    'pics' => array(
        'jpg' => TRUE,
        'png' => TRUE,
        'gif' => TRUE,
    ),
    'music' => array(
        'mp3' => TRUE,
        'aiff' => TRUE,
        'wav' => TRUE,
    ),
);

if( isset( $ext['text'][$format])) // сделать что-то для текста
else if( isset( $ext['pics'][$format])) // что-то для картинок
else if( isset( $ext['music'][$format])) // что-то для музыки
else // что-то по умолчанию
;

In addition, the performance of y if...else, they say , is better than that of switch.

G
GHua, 2014-02-14
@GHua

abstract class AbsctactFileProcessor
{
    abstract public function supports($extension);
    abstract public function process($file);
}

class ProcessingProvider
{
    
    private $processors;

    public function __construct()
    {
        $this->processors = array();
    }

    public function addProcessor(AbsctactFileProcessor $processor)
    {
        $this->processors[] = $processor;

        return $this;
    }

    public function process($file)
    {
        $file = new \SplFileInfo($file);
        $extension = $file->getExtension();
        foreach ($this->processors as $processor) {
            if ($processor->supports($extension)) {

                return $processor->process($file);
            }
        }

        throw new \LogicException();
    }

}

class SimpleTextProcessor extends AbsctactFileProcessor
{

    public function process($file)
    {
        // return ...
    }

    public function supports($extension)
    {
        return in_array($extension, array('txt'));
    }

}

class ImageProcessor extends AbsctactFileProcessor
{

    public function process($file)
    {
        // return ...
    }

    public function supports($extension)
    {
        return in_array($extension, array('png', 'gif', 'bmp', 'jpg'));
    }
}

$provider = new ProcessingProvider();
$provider->addProcessor(new \SimpleTextProcessor());
$provider->addProcessor(new \ImageProcessor());

$provider->process('mybestfile.exe');

N
Nazar Mokrinsky, 2014-02-14
@nazarpc

No, switchit has exactly this recording format

N
nikel303, 2014-02-14
@nikel303

As an option:

switch(true) {

   case ($format == 'text'):
      break;

   case (in_array($format, array('jpg', 'png', 'gif'))):
      break;

   default:
      break;
}

But this one is easier to understand:
case 'text':
   break;

case 'jpg':
case 'png':
case 'gif':
   break;

default:
   break;

S
Sild, 2014-02-14
@Sild

if...

Didn't find what you were looking for?

Ask your question

Ask a Question

731 491 924 answers to any question