ArrayAccessTrait.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\base;
  8. /**
  9. * ArrayAccessTrait provides the implementation for [[\IteratorAggregate]], [[\ArrayAccess]] and [[\Countable]].
  10. *
  11. * Note that ArrayAccessTrait requires the class using it contain a property named `data` which should be an array.
  12. * The data will be exposed by ArrayAccessTrait to support accessing the class object like an array.
  13. *
  14. * @property array $data
  15. *
  16. * @author Qiang Xue <qiang.xue@gmail.com>
  17. * @since 2.0
  18. */
  19. trait ArrayAccessTrait
  20. {
  21. /**
  22. * Returns an iterator for traversing the data.
  23. * This method is required by the SPL interface [[\IteratorAggregate]].
  24. * It will be implicitly called when you use `foreach` to traverse the collection.
  25. * @return \ArrayIterator an iterator for traversing the cookies in the collection.
  26. */
  27. #[\ReturnTypeWillChange]
  28. public function getIterator()
  29. {
  30. return new \ArrayIterator($this->data);
  31. }
  32. /**
  33. * Returns the number of data items.
  34. * This method is required by Countable interface.
  35. * @return int number of data elements.
  36. */
  37. #[\ReturnTypeWillChange]
  38. public function count()
  39. {
  40. return count($this->data);
  41. }
  42. /**
  43. * This method is required by the interface [[\ArrayAccess]].
  44. * @param mixed $offset the offset to check on
  45. * @return bool
  46. */
  47. #[\ReturnTypeWillChange]
  48. public function offsetExists($offset)
  49. {
  50. return isset($this->data[$offset]);
  51. }
  52. /**
  53. * This method is required by the interface [[\ArrayAccess]].
  54. * @param int $offset the offset to retrieve element.
  55. * @return mixed the element at the offset, null if no element is found at the offset
  56. */
  57. #[\ReturnTypeWillChange]
  58. public function offsetGet($offset)
  59. {
  60. return isset($this->data[$offset]) ? $this->data[$offset] : null;
  61. }
  62. /**
  63. * This method is required by the interface [[\ArrayAccess]].
  64. * @param int $offset the offset to set element
  65. * @param mixed $item the element value
  66. */
  67. #[\ReturnTypeWillChange]
  68. public function offsetSet($offset, $item)
  69. {
  70. $this->data[$offset] = $item;
  71. }
  72. /**
  73. * This method is required by the interface [[\ArrayAccess]].
  74. * @param mixed $offset the offset to unset element
  75. */
  76. #[\ReturnTypeWillChange]
  77. public function offsetUnset($offset)
  78. {
  79. unset($this->data[$offset]);
  80. }
  81. }