Use javascript to get a random image from Google images

后端 未结 2 647
遇见更好的自我
遇见更好的自我 2020-12-24 08:17

I have this idea for my website that every time you visit the page, the background will be different. I want to get literally any picture from Google images and place it as

相关标签:
2条回答
  • 2020-12-24 08:32

    It can be done via Google Images though much customization is required so the script behaves as you intended (including setting up a delay to handle rate-limiting; Google has a rate-limit of 64 items per search request over API) here is a basic example using Google Images api:

    <html>
    <head>
        <title></title>
        <script src="https://www.google.com/jsapi"></script>
        <script type="text/javascript">
        google.load('search', '1');
        google.setOnLoadCallback(OnLoad);
        var search;
    
        //i suggest instead of this to make keywords list so first to pick random keyword than to do search and pick random image
        var keyword = 'mountains';
    
        function OnLoad()
        {
            search = new google.search.ImageSearch();
    
            search.setSearchCompleteCallback(this, searchComplete, null);
    
            search.execute(keyword);
        }
    
        function searchComplete()
        {
            if (search.results && search.results.length > 0)
            {
                var rnd = Math.floor(Math.random() * search.results.length);
    
                //you will probably use jQuery and something like: $('body').css('background-image', "url('" + search.results[rnd]['url'] + "')");
                document.body.style.backgroundImage = "url('" + search.results[rnd]['url'] + "')";
            }
        }
        </script>
    </head>
    <body>
    
    </body>
    </html>
    

    However may I suggest instead: Random images from flickr, here is another basic code for that (sky is the limit):

    <html>
    <head>
        <title></title>
        <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
        <script type="text/javascript">
    
        var keyword = "mountains";
    
        $(document).ready(function(){
    
            $.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?jsoncallback=?",
            {
                tags: keyword,
                tagmode: "any",
                format: "json"
            },
            function(data) {
                var rnd = Math.floor(Math.random() * data.items.length);
    
                var image_src = data.items[rnd]['media']['m'].replace("_m", "_b");
    
                $('body').css('background-image', "url('" + image_src + "')");
    
            });
    
        });
        </script>
    </head>
    <body>
    
    </body>
    </html>
    
    0 讨论(0)
  • 2020-12-24 08:53

    although not technically what was asked, this could help give some structure to the randomness -- you could compose a couple dictionaries, of verbs, nouns, adjectives.. and mad-lib it up with a random adjective-noun verbing, (ie, fat bulldog running) then query google with that search, and pick a random picture from the results. this way, you can potentially reduce the inappropriate results, and also allow selection of specific dictionaries based on themes the user has selected perhaps. (ie, changing the available nouns based on user's likes)

    0 讨论(0)
提交回复
热议问题