箭头函数及两种轮播方式

Python021

箭头函数及两种轮播方式,第1张

<script>

        /* 普通函数 */

        /* function fn(){

            return 123

        }

        let a = fn()

        console.log(a)*/

        /* function fn(str){

        let msg = str + 'hello'

        return msg

        }

        let a = fn('张三丰') */

        /* =>箭头函数后面只有一段表达式代表 return 返回 */

        /* let fn = () =>123

        let a = fn()

        console.log(a)*/

        /* 箭头函数只有一个参数()可以省略不写 */

        /* 普通函数可以作为构造函数,箭头函数不能作为构造函数不然会报错 */

        let fn = (str) =>{

            let msg = str +'hello'

            return msg

        }

        let a = fn('张无忌')

        console.log(a)

        /* 普通函数this谁调用就是谁的,箭头函数没有自己的this,箭头函数的this是上下文环境的this */

        /* let obj1 = {

            name:"张三",

            fn:function(){

                console.log(this)

            }

         }

        let obj2 = {

            name:"李四",

         } */

         /* 普通函数的this可以被call 或apply修改 */

         /* obj1.fn.call(obj2) */

         /* 一个参数都没有箭头不能省略 */

         let obj1 = {

            name:"张三",

            fn:()=>{

                /* 目前的环境下的this是window */

                console.log(this)

                }

         }

        let obj2 = {

            name:"李四",

         }

         obj1.fn()/* this指向window 当前上下文环境

         箭头函数的this不会被call 或者apply 修改 */

         obj1.fn.call(obj2)

    </script>

https://v3.bootcss.com/javascript/#carousel

    <style>

        #lunbo{

            width: 600px

            height: 400px

            margin:30px auto

        }

    </style>

</head>

<body>

    <h1>首页</h1>

    <div id="lunbo">

        <div id="carousel-example-generic" class="carousel slide" data-ride="carousel">

            <!-- Indicators 指示器 -->

            <ol class="carousel-indicators">

                <!-- <li data-target="#carousel-example-generic" data-slide-to="0" class="active"></li>

                <li data-target="#carousel-example-generic" data-slide-to="1"></li>

                <li data-target="#carousel-example-generic" data-slide-to="2"></li>-->

            </ol>

            <!-- 主体的图片 -->

            <div class="carousel-inner" role="listbox">

                <!-- <div class="item active">

                    <img style="width: 600pxheight: 400px" src="https://img1.baidu.com/it/u=1436422813,4001806688&fm=253&fmt=auto&app=138&f=JPG?w=936&h=500" alt="...">

                    <div class="carousel-caption">我的小拼</div>

                </div>

                <div class="item">

                    <img style="width: 600pxheight: 400px" src="https://img2.baidu.com/it/u=2356236633,2979184987&fm=253&fmt=auto&app=138&f=JPEG?w=889&h=500" alt="...">

                    <div class="carousel-caption">我的小多</div>

                </div>

                <div class="item">

                    <img style="width: 600pxheight: 400px" src="https://img2.baidu.com/it/u=3429472705,3961913284&fm=253&fmt=auto&app=138&f=JPEG?w=580&h=326" alt="...">

                    <div class="carousel-caption">我的小多多</div>

                </div>-->

            </div>

            <!-- Controls 向左 向右控制图片-->

            <a class="left carousel-control" href="#carousel-example-generic" role="button" data-slide="prev">

                <span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span>

                <span class="sr-only">Previous</span>

            </a>

            <a class="right carousel-control" href="#carousel-example-generic" role="button" data-slide="next">

                <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>

                <span class="sr-only">Next</span>

            </a>

        </div>

    </div>

    <div style="text-align: center">

        <button onclick="prevFn()">向前</button>

        <button onclick="nextFn()">向后</button>

        <button onclick="pauseFn()">暂停</button>

        <button onclick="goDuo()">跳转19岁女大学生失联</button>

        <button onclick="leftR()">从左到右</button>

    </div>

    <script src="./jquery-1.12.4.js"></script>

    <script src="./bootstrap.min.js"></script>

    <script>

        $('.carousel').carousel({

            interval: 2000

        })

        function prevFn(){

            $('.carousel').carousel('prev')

        }

        function nextFn(){

            $('.carousel').carousel('next')

        }

        function pauseFn(){

            $('.carousel').carousel('pause')

        }

        function goDuo(){

            $('.carousel').carousel(1)

        }

        function leftR(){

            $('.carousel').carousel('cycle')

        }

        $.ajax({

            url:"https:调用接口//也可以直接在原文复添加图片地址",

            method:"post",

            data:{

                page:1,

                count:5

            },

            success:res=>{

                let { result } = res

                let str1 = ''

                let str2 = ''

                result.forEach((item,index)=>{

                        str1 +=`

                        <li data-target="#carousel-example-generic" data-slide-to="${index}"></li>

                        `

                        str2 += `

                        <div class="item ">

                            <a href="${item.path}">

                    <img style="width: 600pxheight: 400px" src="${item.image}">

                    <div class="carousel-caption">${item.title}</div>

                </div>

                        `

                    })

                    $('.carousel-indicators').html(str1)

                    $('.carousel-inner').html(str2)

                    $('.carousel-inner .item:first').addClass('active')

            }

        })

    </script>

https://www.swiper.com.cn/usage/index.html

<link rel="stylesheet" href="./swiper-bundle.min.css">

    <style>

        .swiper {

            width: 600px

            height: 300px

        }

        .swiper-slide img {

            width: 600px

            height: 300px

            display: block

        }

    </style>

</head>

<body>

    <div class="swiper">

        <div class="swiper-wrapper">

            <div class="swiper-slide">

                <img src="https://img0.baidu.com/it/u=3519534124,1254775703&fm=253&fmt=auto&app=138&f=JPG?w=889&h=500" alt="">

            </div>

            <div class="swiper-slide">

                <img src="https://img1.baidu.com/it/u=1037786612,1020382020&fm=253&fmt=auto&app=138&f=JPEG?w=889&h=500" alt="">

            </div>

            <div class="swiper-slide">

                <img src="https://img0.baidu.com/it/u=3288667263,3070739640&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=281" alt="">

            </div>

        </div>

        <!-- 如果需要分页器 -->

        <div class="swiper-pagination"></div>

        <!-- 如果需要导航按钮 -->

        <div class="swiper-button-prev"></div>

        <div class="swiper-button-next"></div>

        <!-- 如果需要滚动条 -->

        <!-- <div class="swiper-scrollbar"></div>-->

    </div>

    <script src="./swiper-bundle.min.js"></script>

    <script src="./jquery-1.12.4.js"></script>

    <script>

                /* Swiper('对应的类名') */

                var mySwiper = new Swiper('.swiper', {

                    // direction: 'vertical', // 垂直切换选项

                    loop: true, // 循环模式选项

                    // 如果需要分页器

                    pagination: {

                        el: '.swiper-pagination',

                    },

                    /* 切换反转效果 */

                    effect: 'cube',

                    /* 自动播放效果 */

                    autoplay: {

                        delay: 1000, //1秒切换一次

                    },

                    // 如果需要前进后退按钮

                    navigation: {

                        nextEl: '.swiper-button-next',

                        prevEl: '.swiper-button-prev',

                    },

                    // 如果需要滚动条

                    // scrollbar: {

                    //     el: '.swiper-scrollbar',

                    // },

                })

    </script>

</body>

GO是编译性语言,所以函数的顺序是无关紧要的,为了方便阅读,建议入口函数 main 写在最前面,其余函数按照功能需要进行排列

GO的函数 不支持嵌套,重载和默认参数

GO的函数 支持 无需声明变量,可变长度,多返回值,匿名,闭包等

GO的函数用 func 来声明,且左大括号 { 不能另起一行

一个简单的示例:

输出为:

参数:可以传0个或多个值来供自己用

返回:通过用 return 来进行返回

输出为:

上面就是一个典型的多参数传递与多返回值

对例子的说明:

按值传递:是对某个变量进行复制,不能更改原变量的值

引用传递:相当于按指针传递,可以同时改变原来的值,并且消耗的内存会更少,只有4或8个字节的消耗

在上例中,返回值 (d int, e int, f int) { 是进行了命名,如果不想命名可以写成 (int,int,int){ ,返回的结果都是一样的,但要注意:

当返回了多个值,我们某些变量不想要,或实际用不到,我们可以使用 _ 来补位,例如上例的返回我们可以写成 d,_,f := test(a,b,c) ,我们不想要中间的返回值,可以以这种形式来舍弃掉

在参数后面以 变量 ... type 这种形式的,我们就要以判断出这是一个可变长度的参数

输出为:

在上例中, strs ...string 中, strs 的实际值是b,c,d,e,这就是一个最简单的传递可变长度的参数的例子,更多一些演变的形式,都非常类似

在GO中 defer 关键字非常重要,相当于面相对像中的析构函数,也就是在某个函数执行完成后,GO会自动这个;

如果在多层循环中函数里,都定义了 defer ,那么它的执行顺序是先进后出;

当某个函数出现严重错误时, defer 也会被调用

输出为

这是一个最简单的测试了,当然还有更复杂的调用,比如调试程序时,判断是哪个函数出了问题,完全可以根据 defer 打印出来的内容来进行判断,非常快速,这种留给你们去实现

一个函数在函数体内自己调用自己我们称之为递归函数,在做递归调用时,经常会将内存给占满,这是非常要注意的,常用的比如,快速排序就是用的递归调用

本篇重点介绍了GO函数(func)的声明与使用,下一篇将介绍GO的结构 struct

import "workname/packetfolder"

导入多个包

方法调用 包名.函数//不是函数或结构体所处文件或文件夹名

packagename.Func()

前面加个点表示省略调用,那么调用该模块里面的函数,可以不用写模块名称了:

当导入一个包时,该包下的文件里所有init()函数都会被执行,然而,有些时候我们并不需要把整个包都导入进来,仅仅是是希望它执行init()函数而已。下划线的作用仅仅是为了调用init()函数,所以无法通过包名来调用包中的其他函数

import _ package

变量声明必须要使用否则会报错。

全局变量运行声明但不使用。

func 函数名 (参数1,参数2,...) (返回值a 类型a, 返回值b 类型b,...)

func 函数名 (参数1,参数2,...) (返回值类型1, 返回值类型2,...)

func (this *结构体名) 函数名(参数 string) (返回值类型1, 返回值类型2){}

使用大小来区分函数可见性

大写是public类型

小写是private类型

func prifunc int{}

func pubfunc int{}

声明静态变量

const value int

定义变量

var value int

声明一般类型、接口和结构体

声明函数

func function () int{}

go里面所有的空值对应如下

通道类型

内建函数 new 用来分配内存,它的第一个参数是一个类型,不是一个值,它的返回值是一个指向新分配类型零值的指针

func new(Type) *Type

[这位博主有非常详细的分析] https://www.01hai.com/note/av133981

Go 语言支持并发,我们只需要通过 go 关键字来开启 goroutine 即可。

goroutine 是轻量级线程,goroutine 的调度是由 Golang 运行时进行管理的。

同一个程序中的所有 goroutine 共享同一个地址空间。

语法格式如下:

通道(channel)是用来传递数据的一个数据结构。

通道的声明

通道可用于两个 goroutine 之间通过传递一个指定类型的值来同步运行和通讯。操作符 <- 用于指定通道的方向,发送或接收。如果未指定方向,则为双向通道。

[这里有比较详细的用例] https://www.runoob.com/go/go-interfaces.html

go里面的空接口可以指代任何类型(无论是变量还是函数)

声明空接口

go里面的的强制类型转换语法为:

int(data)

如果是接口类型的强制转成其他类型的语法为:

go里面的强制转换是将值复制过去,所以在数据量的时候有比较高的运行代价