 
- PHP - Home
- PHP - Roadmap
- PHP - Introduction
- PHP - Installation
- PHP - History
- PHP - Features
- PHP - Syntax
- PHP - Hello World
- PHP - Comments
- PHP - Variables
- PHP - Echo/Print
- PHP - var_dump
- PHP - $ and $$ Variables
- PHP - Constants
- PHP - Magic Constants
- PHP - Data Types
- PHP - Type Casting
- PHP - Type Juggling
- PHP - Strings
- PHP - Boolean
- PHP - Integers
- PHP - Files & I/O
- PHP - Maths Functions
- PHP - Heredoc & Nowdoc
- PHP - Compound Types
- PHP - File Include
- PHP - Date & Time
- PHP - Scalar Type Declarations
- PHP - Return Type Declarations
- PHP - Operators
- PHP - Arithmetic Operators
- PHP - Comparison Operators
- PHP - Logical Operators
- PHP - Assignment Operators
- PHP - String Operators
- PHP - Array Operators
- PHP - Conditional Operators
- PHP - Spread Operator
- PHP - Null Coalescing Operator
- PHP - Spaceship Operator
- PHP Control Statements
- PHP - Decision Making
- PHP - If…Else Statement
- PHP - Switch Statement
- PHP - Loop Types
- PHP - For Loop
- PHP - Foreach Loop
- PHP - While Loop
- PHP - Do…While Loop
- PHP - Break Statement
- PHP - Continue Statement
- PHP Arrays
- PHP - Arrays
- PHP - Indexed Array
- PHP - Associative Array
- PHP - Multidimensional Array
- PHP - Array Functions
- PHP - Constant Arrays
- PHP Functions
- PHP - Functions
- PHP - Function Parameters
- PHP - Call by value
- PHP - Call by Reference
- PHP - Default Arguments
- PHP - Named Arguments
- PHP - Variable Arguments
- PHP - Returning Values
- PHP - Passing Functions
- PHP - Recursive Functions
- PHP - Type Hints
- PHP - Variable Scope
- PHP - Strict Typing
- PHP - Anonymous Functions
- PHP - Arrow Functions
- PHP - Variable Functions
- PHP - Local Variables
- PHP - Global Variables
- PHP Superglobals
- PHP - Superglobals
- PHP - $GLOBALS
- PHP - $_SERVER
- PHP - $_REQUEST
- PHP - $_POST
- PHP - $_GET
- PHP - $_FILES
- PHP - $_ENV
- PHP - $_COOKIE
- PHP - $_SESSION
- PHP File Handling
- PHP - File Handling
- PHP - Open File
- PHP - Read File
- PHP - Write File
- PHP - File Existence
- PHP - Download File
- PHP - Copy File
- PHP - Append File
- PHP - Delete File
- PHP - Handle CSV File
- PHP - File Permissions
- PHP - Create Directory
- PHP - Listing Files
- Object Oriented PHP
- PHP - Object Oriented Programming
- PHP - Classes and Objects
- PHP - Constructor and Destructor
- PHP - Access Modifiers
- PHP - Inheritance
- PHP - Class Constants
- PHP - Abstract Classes
- PHP - Interfaces
- PHP - Traits
- PHP - Static Methods
- PHP - Static Properties
- PHP - Namespaces
- PHP - Object Iteration
- PHP - Encapsulation
- PHP - Final Keyword
- PHP - Overloading
- PHP - Cloning Objects
- PHP - Anonymous Classes
- PHP Web Development
- PHP - Web Concepts
- PHP - Form Handling
- PHP - Form Validation
- PHP - Form Email/URL
- PHP - Complete Form
- PHP - File Inclusion
- PHP - GET & POST
- PHP - File Uploading
- PHP - Cookies
- PHP - Sessions
- PHP - Session Options
- PHP - Sending Emails
- PHP - Sanitize Input
- PHP - Post-Redirect-Get (PRG)
- PHP - Flash Messages
- PHP AJAX
- PHP - AJAX Introduction
- PHP - AJAX Search
- PHP - AJAX XML Parser
- PHP - AJAX Auto Complete Search
- PHP - AJAX RSS Feed Example
- PHP XML
- PHP - XML Introduction
- PHP - Simple XML Parser
- PHP - SAX Parser Example
- PHP - DOM Parser Example
- PHP Login Example
- PHP - Login Example
- PHP - Facebook Login
- PHP - Paypal Integration
- PHP - MySQL Login
- PHP Advanced
- PHP - MySQL
- PHP.INI File Configuration
- PHP - Array Destructuring
- PHP - Coding Standard
- PHP - Regular Expression
- PHP - Error Handling
- PHP - Try…Catch
- PHP - Bugs Debugging
- PHP - For C Developers
- PHP - For PERL Developers
- PHP - Frameworks
- PHP - Core PHP vs Frame Works
- PHP - Design Patterns
- PHP - Filters
- PHP - JSON
- PHP - Exceptions
- PHP - Special Types
- PHP - Hashing
- PHP - Encryption
- PHP - is_null() Function
- PHP - System Calls
- PHP - HTTP Authentication
- PHP - Swapping Variables
- PHP - Closure::call()
- PHP - Filtered unserialize()
- PHP - IntlChar
- PHP - CSPRNG
- PHP - Expectations
- PHP - Use Statement
- PHP - Integer Division
- PHP - Deprecated Features
- PHP - Removed Extensions & SAPIs
- PHP - PEAR
- PHP - CSRF
- PHP - FastCGI Process
- PHP - PDO Extension
- PHP - Built-In Functions
PHP - Ds Vector::slice() Function
The PHPDs\Vector::slice()function is used to retrieve a sub-vector of the given range from the original vector. The sub-vector is a part of the original vector. For example, vector {1, 2} is a sub-vector of this original vector {1, 2, 3}.
This function accepts an optional parameter named 'length'. Below is the list of key points about this parameter −
- If the 'length' is negative, the vector stops that many elements from the end.
- If the 'length' is positive, the sub-vector has that many elements in it.
- If the 'length' exceeds the vector size, only values up to the end of the vector will be included.
- If the 'length' is not provided, the sub-vector will contain all the values between the 'index' and the end of the vector.
Syntax
Following is the syntax of the PHP Ds\Vector::slice() function −
public Ds\Vector::slice(int $index, int $length = ?): Ds\Vector
Parameters
Following are the parameters of this function −
- index − The index at which the sub-vector starts extracting.
- length − The length of the sub-vector.
Return value
This function returns a sub-vector of the given range.
Example 1
Following is the basic example of the PHP Ds\Vector::slice() function −
<?php   
   $vector = new \Ds\Vector([1, 2, 3, 4, 5]);  
   echo("The original vector: \n");   
   print_r($vector);
   $index = 1;
   $length = 2;
   echo "The index and length is: ".$index.", ".$length;
   #using slice() function
   $result = $vector->slice(1, 2); 
   echo("\nThe new sub-vector:\n");  
   print_r($result);
?>
Output
The above program produces the following output −
The original vector:
Ds\Vector Object
(
    [0] => 1
    [1] => 2
    [2] => 3
    [3] => 4
    [4] => 5
)
The index and length is: 1, 2
The new sub-vector:
Ds\Vector Object
(
    [0] => 2
    [1] => 3
)
Example 2
If the length is negative, the vector will stop that many values from the end.
Following is another example of the PHP Ds\Vector::slice() function. We use this function to retrieve a sub-vector from the original vector of the given range (1, -2) −
<?php 
   $vector = new \Ds\Vector([10, 20, 30, 40, 50]);
   echo("The original vector: \n");
   print_r($vector);
   $index = 1;
   $length = -2;
   echo "The index and length is: ".$index.", ".$length;
   $result = $vector->slice(1, -2);
   echo("\nThe new sub-vector: \n");
   print_r($result);
?>
Output
After executing the above program, the following output will be displayed −
The original vector:
Ds\Vector Object
(
    [0] => 10
    [1] => 20
    [2] => 30
    [3] => 40
    [4] => 50
)
The index and length is: 1, -2
The new sub-vector:
Ds\Vector Object
(
    [0] => 20
    [1] => 30
)
Example 3
If the length value exceeds the vector size, only values up to the end of the vector will be included.
<?php 
   $vector = new \Ds\Vector(["Tutorials", "Point", "India"]);
   echo("The original vector: \n");
   print_r($vector);
   $index = 0;
   $length = 10;
   echo "The index and length is: ".$index.", ".$length;
   $result = $vector->slice($index, $length);
   echo("\nThe new sub-vector: \n");
   print_r($result);
?>
Output
Once the above program is executed, it will display the following output −
The original vector:
Ds\Vector Object
(
    [0] => Tutorials
    [1] => Point
    [2] => India
)
The index and length is: 0, 10
The new sub-vector:
Ds\Vector Object
(
    [0] => Tutorials
    [1] => Point
    [2] => India
)
Example 4
If a length is not provided, the resulting vector will contain all values between the index and the end of the vector.
<?php 
   $vector = new \Ds\Vector(['a', 'e', 'i', 'o', 'u']);
   echo("The original vector: \n");
   print_r($vector);
   $index = 2;
   echo "The index is: ".$index;
   $result = $vector->slice($index);
   echo("\nThe new sub-vector: \n");
   print_r($result);
?>
Output
Following is the output of the above program −
The original vector:
Ds\Vector Object
(
    [0] => a
    [1] => e
    [2] => i
    [3] => o
    [4] => u
)
The index is: 2
The new sub-vector:
Ds\Vector Object
(
    [0] => i
    [1] => o
    [2] => u
)