十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
script

成都創(chuàng)新互聯(lián)專注于企業(yè)網(wǎng)絡(luò)營銷推廣、網(wǎng)站重做改版、商水網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5頁面制作、商城開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)公司、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為商水等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
? ? /* 普通函數(shù) */
? ? /* function fn(){
? ? ? ? return 123
? ? }
? ? let a = fn();
? ? console.log(a); */
? /* function fn(str){
? ? let msg = str + 'hello'
? ? return msg
? ? }
? ? let a = fn('張三豐') */
? /* =箭頭函數(shù)后面只有一段表達(dá)式代表 return 返回 */
? ? /* let fn = () = 123;
? ? let a = fn();
? ? console.log(a); */
? /* 箭頭函數(shù)只有一個(gè)參數(shù)()可以省略不寫 */
? ? /* 普通函數(shù)可以作為構(gòu)造函數(shù),箭頭函數(shù)不能作為構(gòu)造函數(shù)不然會(huì)報(bào)錯(cuò) */
? ? let fn = (str) ={
? ? ? ? let msg = str +'hello'
? ? ? ? return msg
? ? }
? ? let a = fn('張無忌')
? ? console.log(a);
? ? /* 普通函數(shù)this誰調(diào)用就是誰的,箭頭函數(shù)沒有自己的this,箭頭函數(shù)的this是上下文環(huán)境的this */
? ? /* let obj1 = {
? ? ? ? name:"張三",
? ? ? ? fn:function(){
? ? ? ? ? ? console.log(this)
? ? ? ? }
? ? ?}
? ? let obj2 = {
? ? ? ? name:"李四",
? ?} */
? ? ?/* 普通函數(shù)的this可以被call 或apply修改 */
? ? ?/* obj1.fn.call(obj2) */
? ? ?/* 一個(gè)參數(shù)都沒有箭頭不能省略 */
? ? ?let obj1 = {
? ? ? ? name:"張三",
? ? ? ? fn:()={
? ? ? ? ? ? /* 目前的環(huán)境下的this是window */
? ? ? ? ? ? console.log(this);
? ? ? ? ? ? }
? ? ?}
? ? let obj2 = {
? ? ? ? name:"李四",
? ?}
? ? ?obj1.fn()/* this指向window 當(dāng)前上下文環(huán)境
? ? ?箭頭函數(shù)的this不會(huì)被call 或者apply 修改 */
? ? ?obj1.fn.call(obj2)
/script
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: 600px;height: 400px;" src=";fm=253fmt=autoapp=138f=JPG?w=936h=500" alt="..."
? ? ? ? ? ? ? ? div class="carousel-caption"我的小拼/div
? ? ? ? ? ? /div
? ? ? ? ? ? div class="item"
? ? ? ? ? ? ? ? img style="width: 600px;height: 400px;" src=";fm=253fmt=autoapp=138f=JPEG?w=889h=500" alt="..."
? ? ? ? ? ? ? ? div class="carousel-caption"我的小多/div
? ? ? ? ? ? /div
? ? ? ? ? ? div class="item"
? ? ? ? ? ? ? ? img style="width: 600px;height: 400px;" src=";fm=253fmt=autoapp=138f=JPEG?w=580h=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()"跳轉(zhuǎn)19歲女大學(xué)生失聯(lián)/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:調(diào)用接口//也可以直接在原文復(fù)添加圖片地址",
? ? ? ? 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: 600px;height: 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
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=";fm=253fmt=autoapp=138f=JPG?w=889h=500" alt=""
? ? ? ? /div
? ? ? ? div class="swiper-slide"
? ? ? ? ? ? img src=";fm=253fmt=autoapp=138f=JPEG?w=889h=500" alt=""
? ? ? ? /div
? ? ? ? div class="swiper-slide"
? ? ? ? ? ? img src=";fm=253fmt=autoapp=138f=JPEG?w=500h=281" alt=""
? ? ? ? /div
? ? /div
? ? !-- 如果需要分頁器 --
? ? div class="swiper-pagination"/div
? ? !-- 如果需要導(dǎo)航按鈕 --
? ? div class="swiper-button-prev"/div
? ? div class="swiper-button-next"/div
? ? !-- 如果需要滾動(dòng)條 --
? ? !-- div class="swiper-scrollbar"/div --
/div
script src="./swiper-bundle.min.js"/script
script src="./jquery-1.12.4.js"/script
script
? ? ? ? ? /* Swiper('對(duì)應(yīng)的類名') */
? ? ? ? ? ? var mySwiper = new Swiper('.swiper', {
? ? ? ? ? ? ? ? // direction: 'vertical', // 垂直切換選項(xiàng)
? ? ? ? ? ? ? ? loop: true, // 循環(huán)模式選項(xiàng)
? ? ? ? ? ? ? ? // 如果需要分頁器
? ? ? ? ? ? ? ? pagination: {
? ? ? ? ? ? ? ? ? ? el: '.swiper-pagination',
? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? /* 切換反轉(zhuǎn)效果 */
? ? ? ? ? ? ? ? effect: 'cube',
? ? ? ? ? ? ? ? /* 自動(dòng)播放效果 */
? ? ? ? ? ? ? ? autoplay: {
? ? ? ? ? ? ? ? ? ? delay: 1000, //1秒切換一次
? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? // 如果需要前進(jìn)后退按鈕
? ? ? ? ? ? ? ? navigation: {
? ? ? ? ? ? ? ? ? ? nextEl: '.swiper-button-next',
? ? ? ? ? ? ? ? ? ? prevEl: '.swiper-button-prev',
? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? // 如果需要滾動(dòng)條
? ? ? ? ? ? ? ? // scrollbar: {
? ? ? ? ? ? ? ? // ? ? el: '.swiper-scrollbar',
? ? ? ? ? ? ? ? // },
? ? ? ? ? ? })
/script
/body
GO是編譯性語言,所以函數(shù)的順序是無關(guān)緊要的,為了方便閱讀,建議入口函數(shù) main 寫在最前面,其余函數(shù)按照功能需要進(jìn)行排列
GO的函數(shù) 不支持嵌套,重載和默認(rèn)參數(shù)
GO的函數(shù) 支持 無需聲明變量,可變長度,多返回值,匿名,閉包等
GO的函數(shù)用 func 來聲明,且左大括號(hào) { 不能另起一行
一個(gè)簡單的示例:
輸出為:
參數(shù):可以傳0個(gè)或多個(gè)值來供自己用
返回:通過用 return 來進(jìn)行返回
輸出為:
上面就是一個(gè)典型的多參數(shù)傳遞與多返回值
對(duì)例子的說明:
按值傳遞:是對(duì)某個(gè)變量進(jìn)行復(fù)制,不能更改原變量的值
引用傳遞:相當(dāng)于按指針傳遞,可以同時(shí)改變?cè)瓉淼闹?,并且消耗的?nèi)存會(huì)更少,只有4或8個(gè)字節(jié)的消耗
在上例中,返回值 (d int, e int, f int) { 是進(jìn)行了命名,如果不想命名可以寫成 (int,int,int){ ,返回的結(jié)果都是一樣的,但要注意:
當(dāng)返回了多個(gè)值,我們某些變量不想要,或?qū)嶋H用不到,我們可以使用 _ 來補(bǔ)位,例如上例的返回我們可以寫成 d,_,f := test(a,b,c) ,我們不想要中間的返回值,可以以這種形式來舍棄掉
在參數(shù)后面以 變量 ... type 這種形式的,我們就要以判斷出這是一個(gè)可變長度的參數(shù)
輸出為:
在上例中, strs ...string 中, strs 的實(shí)際值是b,c,d,e,這就是一個(gè)最簡單的傳遞可變長度的參數(shù)的例子,更多一些演變的形式,都非常類似
在GO中 defer 關(guān)鍵字非常重要,相當(dāng)于面相對(duì)像中的析構(gòu)函數(shù),也就是在某個(gè)函數(shù)執(zhí)行完成后,GO會(huì)自動(dòng)這個(gè);
如果在多層循環(huán)中函數(shù)里,都定義了 defer ,那么它的執(zhí)行順序是先進(jìn)后出;
當(dāng)某個(gè)函數(shù)出現(xiàn)嚴(yán)重錯(cuò)誤時(shí), defer 也會(huì)被調(diào)用
輸出為
這是一個(gè)最簡單的測試了,當(dāng)然還有更復(fù)雜的調(diào)用,比如調(diào)試程序時(shí),判斷是哪個(gè)函數(shù)出了問題,完全可以根據(jù) defer 打印出來的內(nèi)容來進(jìn)行判斷,非??焖?,這種留給你們?nèi)?shí)現(xiàn)
一個(gè)函數(shù)在函數(shù)體內(nèi)自己調(diào)用自己我們稱之為遞歸函數(shù),在做遞歸調(diào)用時(shí),經(jīng)常會(huì)將內(nèi)存給占滿,這是非常要注意的,常用的比如,快速排序就是用的遞歸調(diào)用
本篇重點(diǎn)介紹了GO函數(shù)(func)的聲明與使用,下一篇將介紹GO的結(jié)構(gòu) struct
當(dāng)我們將一種功能用于多個(gè)地方的時(shí)候,就需要封裝這些功能,以便于多次使用,然而封裝就需要使用函數(shù)來進(jìn)行封裝,因此本章我們就來說說函數(shù)的使用方法。我們先來看看涉及到函數(shù)的一些用法目錄。如下:
無參函數(shù)
有參函數(shù)
帶返回值的函數(shù)
帶多個(gè)返回值的函數(shù)
匿名函數(shù)
閉包
自調(diào)用
遞歸
本章內(nèi)容還是比較豐富的,請(qǐng)耐心往下看。
1、goroutine:在go語言中,每一個(gè)并發(fā)的執(zhí)行單元叫做goroutine,如果一個(gè)程序中包含多個(gè)goroutine,對(duì)兩個(gè)函數(shù)的調(diào)用則可能發(fā)生在同一時(shí)刻
2、main goroutine:當(dāng)一個(gè)程序啟動(dòng)時(shí),其主函數(shù)即在一個(gè)單獨(dú)的goroutine中運(yùn)行,我們叫他為main gorountine
3、go goroutine:新的goroutine會(huì)用go語句來創(chuàng)建,go+函數(shù)名,go語句會(huì)使其語句中的函數(shù)在一新創(chuàng)建的goroutine中運(yùn)行,而go語句本身會(huì)迅速地完成
4、goroutine的退出:主函數(shù)返回時(shí),所有的goroutine都會(huì)被直接打斷,程序退出,除了從主函數(shù)退出或者終止程序之外,沒有其他方法能夠讓一個(gè)goroutine來打斷另一個(gè)的執(zhí)行,但是可以通過另一種方式來實(shí)現(xiàn)這個(gè)目的,通過goroutine之間的通信來讓一個(gè)goroutine請(qǐng)求其他的goroutine,并讓請(qǐng)求的goroutine自行結(jié)束執(zhí)行