Skip to content

Instantly share code, notes, and snippets.

@6174
Created July 23, 2013 13:36
Show Gist options
  • Save 6174/6062387 to your computer and use it in GitHub Desktop.
Save 6174/6062387 to your computer and use it in GitHub Desktop.
Generate a random string in JavaScript In a short and fast way!
//http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript
Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15);
@migue802
Copy link

Noice. 👌 Thanks!!

@usayamadx
Copy link

Awesome!!!

@BlueProgrammer212
Copy link

Pretty cool!

@KnJbMfLAgdkwZL
Copy link

Brilliant!

@Montazu
Copy link

Montazu commented Jan 6, 2022

This is my version. Generate random string with numbers, lower and upper case.

const randomString=length=>Math.random().toString(36).substr(2,length).split("").map(e=>Math.random()<Math.random()?e.toUpperCase():e).join().replaceAll(",","");

console.log(randomString(10)); //8itPVoPBdU

@ughitsaaron
Copy link

Using recursion with the option of providing a prefix.

function randomStr(minLength = 0, acc = '') {
    if (acc.length <= minLength) {
        const str = Math.random().toString(36).slice(2);
        return randomStr(minLength, acc.concat(str))
    }

    return acc.slice(0, minLength);
}

randomStr(10) // => 'fvaj2hm2na'
randomStr(30, 'https://short.codes/') // => 'https://short.codes/jtmx66qr06'

@zeelkakdiya
Copy link

  const idString = async (string_length) => {
    var random_str = "";
    var characters =
      "ABCDEFGHIJKLMNOPQRSTUVWXYZqeytrpolkadjsghfgmnbzxcvnQPOWEYRKASJHDGFMNBCVX--___-_jsfhrlg-_124903564576986483658fgh4sdfh687e4h897WETHJ68F7G4688471877GFHJFFGJ87469857468746hfghwrtiyj4598yhdjkhgnk";
    for (let index = 0; index < string_length; index++) {
      random_str += characters.charAt(
        Math.floor(Math.random() * characters.length)
      );
    }
    let string = `${random_str}`;
    console.log(string);
    return string;
  };

@adam-cyclones
Copy link

adam-cyclones commented Jul 6, 2022

@zeelkakdiya constructive feedback to improve this code:

  1. This is not an async function, it does not use promises
  2. var is used rather than let and in some cases const are more appropriate
  3. let string does not need ${}
  4. console.log is not useful in production code and actually slows down this function
  5. let string to return could be removed.
  6. casing is inconsistent
const generateID = (stringLength = 20) => {
    let randomStr = "";
    const characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZqeytrpolkadjsghfgmnbzxcvnQPOWEYRKASJHDGFMNBCVX--___-_jsfhrlg-_124903564576986483658fgh4sdfh687e4h897WETHJ68F7G4688471877GFHJFFGJ87469857468746hfghwrtiyj4598yhdjkhgnk";
    for (let index = 0; index < stringLength; index++) {
      randomStr += characters.charAt(
        Math.floor(Math.random() * characters.length)
      );
    }
    return randomStr;
  };

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment