先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
正文
“position”: “bottom”,
“list”: [
{
“text”: “首页”,
“pagePath”: “pages/index/index”,
“iconPath”: “img/tabBarImg/shouye_1.png”,
“selectedIconPath”: “img/activeTabbar/shouye_1.png”
},
{
“text”: “朋友圈”,
“pagePath”: “pages/index/index”,
“iconPath”: “img/tabBarImg/quanziguanli.png”,
“selectedIconPath”: “img/activeTabbar/quanziguanli.png”
},
{
“text”: “更多”,
“pagePath”: “pages/index/index”,
“iconPath”: “img/tabBarImg/gengduo.png”,
“selectedIconPath”: “img/activeTabbar/gengduo.png”
},
]
},
微信小程序的事件传值
// 在循环的标签上面加入 传入没一项data-item=“{{item}}” 要用 {{}} 包裹因为他是变量 传入下标 data-index=“{{index}}”
// bindtap 小程序的事件点击
{{item.name}}
// 通过事件对象 可以拿到穿过来的值
toReadText(e:any){
console.log(e.currentTarget.dataset.item.id);
},
微信小程序的组件
// 新建一个 components 文件夹专门用来放组件 在面面在建一个文件夹 选中文件夹然后右键 新建Component
// 里面的有个 json 文件 component 为true
{
“component”: true,
“usingComponents”: {}
}
// 在页面用找到 json 文件 usingComponents 写入路径 页面写入组件即可就可以使用了
{
“usingComponents”: {
“novelList”:“…/…/compotent/novelList/novelList”,
“bookList”:“/compotent/bookList/bookList”,
}
}
// 全局组件 也可以 找到app.json 文件 在里面写入 就是全局组件了
微信小程序的组件通信
// 页面传子组件 在组件上面写入属性 变量 bookData {{}}给括起来 字符串不许要括起来
// 子组件里面找到在 properties 写入接收的数据
properties: {
bookData:{
type:Array, // 类型
},
imgFlag:{
type:Boolean, // 类型
value:false // 默认值
}
},
// 子组件传父组件 在页面中的子组件标签上写自定义事件 事件的名字 ageTabs
// 页面
// 子组件事件触发相当于vue 的emit ageTabs 事件名字
ageTAabSwidch(){
this.triggerEvent(‘ageTabs’,‘我是数据’)
},
微信小程序插槽的使用
链接:https://blog.csdn.net/qq_54753561/article/details/121796270
微信小程序的循环
// wx:for-item=“item1” 指定下一次的每一项 默认是 item 是每一项
// wx:for=“{{Floordata}}” wx的for 循环 Floordata 数据一定要用 {{}}} 包裹
// wx:key=“index” 这个不用加上 {{}}
微信小程序的修改数据
小程序通过赋值 更该数据的话是无法 同步视图的,必须通过 this.setData({}) 来修改
// pages/search/search.ts
import {Search,SearchHotVal,getSearchValue} from ‘…/…/api/api’
Page({
/**
- 页面的初始数据
*/
data: {
searchHistory:[],
},
// 搜索的事件
onSearch(e:any){
// 解构
let {query,booksData,searchHistory,hintIsShow} = this.data
// 增加数据
searchHistory.unshift({
id:new Date().getTime(),
val:e.detail.value
})
// 修改
this.setData({
query:e.detail.value,
searchHistory,
hintIsShow:false
})
}
onLoad() {
// 页面加载村本地存储重新赋值 取得时候一定要是一个空数组
this.setData({
searchHistory:wx.getStorageSync(‘searchValue’) || []
})
},
})
微信小程序混入
// 新建一个 mixins文件 在页面的Page中导入我们的 mixins 文件
import mixins from ‘./mixins’
Page({
behaviors:[mixins],
/*behaviors
behaviors 是用于组件间代码共享的特性,类似于一些编程语言中的 “mixins” 或 “traits”。
每个 behavior 可以包含一组属性、数据、生命周期函数和方法。组件引用它时,它的属性、数据和方法会被合并到组件中,生命周期函数也会在对应时机被调用。 每个组件可以引用多个 behavior ,behavior 也可以引用其它 behavior 。*/
})
mixins 文件夹写入
export default Behavior({
data:{
// 存放数据的地方
},
methods:{
// 请求方法的接口 要写到 methods 中
readText(sectionIdParams:number,idParams:number) {
let {dataText,sectionId,id} = this.data // 可以拿到主文件的data
},
}
})
官方地址为准:https://developers.weixin.qq.com/miniprogram/dev/framework/custom-component/behaviors.html
微信小程序的登录流程
1.用 wx.login API 先获取一个临时凭证 拿到他的 conde
2.用这个 code + addId + 凭证码
获取三个id:
openid
每个用户的固定id
session_key 临时的会话存储凭证
-
wx.getSetting 使用 getUserInfo 获取用户的信息
-
用户信息获取第三方接口的 token
最后
总的来说,面试官要是考察思路就会从你实际做过的项目入手,考察你实际编码能力,就会让你在电脑敲代码,看你用什么编辑器、插件、编码习惯等。所以我们在回答面试官问题时,有一个清晰的逻辑思路,清楚知道自己在和面试官说项目说技术时的话就好了
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
什么编辑器、插件、编码习惯等。所以我们在回答面试官问题时,有一个清晰的逻辑思路,清楚知道自己在和面试官说项目说技术时的话就好了
[外链图片转存中…(img-fnz7Kvpl-1713546658511)]
[外链图片转存中…(img-96yEMwdF-1713546658511)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-8uJQXBVy-1713546658511)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!