Converting Non-Decimal Strings with Laravel's Enhanced toInteger() Method
Last updated on by Harris Raftopoulos

Laravel has improved its Stringable class with an expanded toInteger() method that now accepts a base parameter, making it easier to handle hexadecimal, binary, and octal string values within your applications.
Developers frequently need to convert between string representations of numbers in various bases. Previously, this often required breaking out of Laravel's fluent string operations to use PHP's native functions. The updated toInteger() method allows these conversions to happen seamlessly within your string manipulation chains.
Here's the method in action:
// Convert hex string to integer$value = Str::of('2F')->toInteger(16); // Returns 47// Convert binary string to integer$value = Str::of('11001')->toInteger(2); // Returns 25// Convert octal string to integer$value = Str::of('644')->toInteger(8); // Returns 420
This enhancement proves especially valuable when working with formats like color codes, binary data, or configuration settings that use non-decimal number systems. Consider this example processing a hexadecimal color:
// Previously: Breaking the fluent chain$hexColor = '#3f8ac2';$stringable = Str::of($hexColor)->after('#');$colorValue = intval($stringable, 16); // Now: Maintaining fluency throughout$colorValue = Str::of($hexColor) ->after('#') ->toInteger(16);
The method integrates seamlessly with other string manipulation features, enabling more complex operations:
// Parse and convert hex value from sensor data$data = 'Sensor: reading=0x4B, status=0x03'; $reading = Str::of($data) ->between('reading=', ',') // Extract "0x4B" ->replaceFirst('0x', '') // Remove "0x" prefix ->toInteger(16); // Convert to decimal (75)
Following the same conventions as PHP's native intval() function, the base parameter supports values from 2 to 36, giving you flexibility to handle a wide spectrum of number system conversions while preserving Laravel's elegant fluent syntax.