2012-10-04 14 views
10

Sass 3.2.1Sassの文字列置換

文字列の一部をテキストの一部に置き換えるにはどうすればよいですか?たとえば、色#fefefeからダッシュ#を削除してfefefeにします。

ありがとうございます!

+1

文字列操作は、現在、コア言語の一部ではありませんが、それは将来的に追加される可能性があるように見えます:ヒントのhttps://github.com/nex3/sass/pull/401 – cimmanon

+0

ありがとう! –

答えて

0

(Mac用の私の場合は)単純な一時的な解決策:ここ

$ git clone -b string_functions https://github.com/chriseppstein/sass 
$ cd sass 
$ sudo rake install 

$ sudo mv /usr/bin/sass /usr/bin/sass.orig 
$ sudo ln -s /Library/Ruby/Gems/1.8/gems/sass-3.2.0.alpha.0/bin/sass /usr/bin/sass 
+1

「カスタム関数の追加」のセクションを参照してください。http://sass-lang.com/documentation/Sass/Script/Functions.html – svallory

10

は、私はちょうど使用する機能です!

SCSS機能

/// Replace `$search` with `$replace` in `$string` 
/// @author Hugo Giraudel 
/// @param {String} $string - Initial string 
/// @param {String} $search - Substring to replace 
/// @param {String} $replace ('') - New value 
/// @return {String} - Updated string 
@function str-replace($string, $search, $replace: '') { 
    $index: str-index($string, $search); 

    @if $index { 
    @return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace); 
    } 

    @return $string; 
} 

SCSS-USAGE:

.selector { 
    $string: 'The answer to life the universe and everything is 42.'; 
    content: str-replace($string, 'e', 'xoxo'); 
} 

SCSS結果:

.selector { 
    content: "Thxoxo answxoxor to lifxoxo thxoxo univxoxorsxoxo and xoxovxoxorything is 42."; 
} 

Source of SCSS-example

私はインデント付きのスタイルでSASSを使用しています。これは、バックグラウンドでhrefインラインエンコードされたCSSのsvg-imageを置き換えるカラー変数を取得する私の変換です。 #はURLエンコードされている必要があります。グローバルな色を使用するのは、1か所だけで置き換えて、単に機能させるだけです!

SASS機能:

@function str-replace($string, $search, $replace: '') 
    $index: str-index($string, $search) 
    @if $index 
    @return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace) 
    @return $string 

SASS-USAGE:

$color-blue-night: #172b47  
$icon-normal: str-replace('' + $color-blue-night, '#', '') 

またはクリア例えば

.test 
    color: str-replace('' + $color-blue-night, '#', '') 

SASS結果:

.test { 
    color: "172b47"; }