Camelize, CamelCase

Montag, 20. Oktober 2008

Wie in der post Vielfalt der Kodierung und die Kodierung der Ansätze, die Entwickler haben zur Lösung eines Problems zu sehen sind vielfältig und viele der verwendeten Programmiersprache. Hier ist, wie einige der bekanntesten JavaScript-Frameworks haben eine einfache Funktion der CamelCase gelöst:

Prototype.js

Prototype.js, Version 1.6.0.3, schlagen ein explizites Verfahren camelize() die camelcase auf einem String zu machen. The author's Ansatz ist ganz einfach und der Code ist selbsterklärend. In diesem Fall wurde nicht die Verwendung von regulären Ausdrücken!

JavaScript:
  1. ( ) { camelize Funktion: () (
  2. this . split ( '-' ) , len = parts. length ; var Teile = this. split ('-'), len = Teile. Länge;
  3. len == 1 ) return parts [ 0 ] ; if (len == 1) return parts [0];
  4. this . charAt ( 0 ) == '-' camelized var = this. charAt (0) == '-'
  5. 0 ] . charAt ( 0 ) . toUpperCase ( ) + parts [ 0 ] . substring ( 1 ) ? Teile [0]. CharAt (0). ToUpperCase () + parts [0]. Substring (1)
  6. 0 ] ; : Teile [0];
  7. var i = 1 ; i < len ; i ++ ) for (var i = 1; i <len; i + +)
  8. i ] . charAt ( 0 ) . toUpperCase ( ) + parts [ i ] . substring ( 1 ) ; camelized + = parts [i]. charAt (0). toUpperCase () + parts [i]. substring (1);
  9. camelized return;
  10. )

Nutzen Sie auch einen Blick auf diese interessante Debatte.

mootools

Bibliothek mootools, Version 1.2, schlägt außerdem vor, eine Methode camelCase() In diesem Fall ist die Funktion wesentlich kompakter als im Vorschlag Prototype.js, dank der Verwendung von regulären Ausdrücken.

JavaScript:
  1. ( ) { camelCase: function () (
  2. ( /-\D/g , function ( match ) { return this ersetzen. (/ - \ D / g, function (Spiel) (
  3. ( 1 ) . toUpperCase ( ) ; Rückspiel. charAt (1). toUpperCase ();
  4. ));
  5. )

jQuery

jQuery, ist Version 1.2.6, nicht vor ein explizites Verfahren. Dennoch, mit Blick in den Code, fand ich diese:

JavaScript:
  1. name . replace ( /\-(\w)/g , function ( all , letter ) { return letter. toUpperCase ( ) ; } ) ; var = name camelCase. replace (/ \ - (\ w) / g, function (alle, Brief) (return Brief. toUpperCase ();));

Außerdem ist, wie ein Plugin, bietet jQuery ein String Prototyp Erweiterungen hinzugefügt, wo gerade eine Funktion camelize()

JavaScript:
  1. / **
  2. * Zurück zur camelized String, die Beseitigung aller Unterstriche und Bindestriche
  3. * Und ersetzt sie durch Groß-Darstellung das nächste Zeichen ist.
  4. *
  5. * @ Example "font-weight". Camelize ()
  6. * @ Result "fontWeight"
  7. *
  8. * @ Example "border_width_bottom. Camelize ()
  9. * @ Result "borderWidthBottom"
  10. *
  11. * @ Example "border_width-bottom". Camelize ()
  12. * @ Result "borderWidthBottom"
  13. *
  14. * @ Name camelize
  15. * @ Typ String
  16. * @ Cat JavaScript / String
  17. * /
  18. , function ( ) { add ( "camelize", function () (
  19. ( /[-_]([az])/ig , function ( z , b ) { return b. toUpperCase ( ) ; } ) ; return this. ersetzen (/[-_]([ az]) / ig, function (z, b) (return b toUpperCase ();));
  20. ));

Dies insbesondere, berücksichtigt die Zeichen underscore (_) so wird vollständiger.

Verwandte Post

War dieser Artikel hilfreich?: Per nientePocoAbbastanzaMoltoMoltissimo
Loading ... Loading ...

Ein Kommentar zu "camelize, CamelCase"

  1. getAvatar 1,0
    28. Mai 2009 Undolog.com "Sehr kurze Auszug: PHP Slug:

    [...] In "this-and-a-post". Die Umwandlung ist vergleichbar mit dem der Schnecke camelize oder camelcase, hier zu sehen. Hier ist eine mögliche Umsetzung in PHP: PLAIN TEXT [...]

Leave a comment

TAG XHTML Berechtigungen: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong> INSERTION CODE:
 <pre></pre>         // blocco generico [code][/code]       // blocco generico [as][/as]           // Actionscript [css][/css]         // CSS Style Sheet [html][/html]       // HTML [js][/js]           // Javascript [objc][/objc]       // Objective-C [php][/php]         // PHP [sql][/sql]         // SQL