Vue.js Google Adsense Component with InFeed and InArticle Ads support
You are seing [email protected] which ONLY compatible for Vue 3, if you want to support Vue 2, please use [email protected].
Documentation for [email protected] can be found on the branch v1-for-vue2
https://mazipan.github.io/vue-google-adsense/
At least there is three (3) type ads in Google Adsense :
- 
Responsive Ads: A simple way to get ads on your page. Choose the size, placement and style you want to display. Learn more 
- 
In Article Ads: Ads that fit seamlessly in between the paragraphs of your pages for an enhanced reading experience. Learn more 
- 
In Feed Ads: Ads that flow naturally inside a list of articles or products on your site, offering a great user experience. Learn more 
Need dependencies vue-scriptx, you need to install :
npm install vue-scriptx vue-google-adsense@next --saveimport ScriptX from 'vue-scriptx'
app.use(ScriptX)
import Ads from 'vue-google-adsense'
app.use(Ads.Adsense)
app.use(Ads.InArticleAdsense)
app.use(Ads.InFeedAdsense)Import only AdsType you need
import Adsense from 'vue-google-adsense/dist/Adsense.min.js'
import InArticleAdsense from 'vue-google-adsense/dist/InArticleAdsense.min.js'
import InFeedAdsense from 'vue-google-adsense/dist/InFeedAdsense.min.js'
import ScriptX from 'vue-scriptx'
app.use(ScriptX)
app.use(Adsense)
app.use(InArticleAdsense)
app.use(InFeedAdsense)Create file plugins/vue-google-adsense.js, with code :
import Vue from 'vue'
import Ads from 'vue-google-adsense'
Vue.use(require('vue-script2'))
Vue.use(Ads.Adsense)
Vue.use(Ads.InArticleAdsense)
Vue.use(Ads.InFeedAdsense)Then update your nuxt.config.js, with code :
module.exports = {
  plugins: [
    { src: '~/plugins/vue-google-adsense', ssr: false }
  ]
}Insert these code in src/main.js:
// The Client API can be used here. Learn more: gridsome.org/docs/client-api
export default function (Vue, { router, head, isClient }) {
 if (isClient) {
   Vue.use(require('vue-script2'));
   Vue.use(require('vue-google-adsense/dist/Adsense.min.js'));
   Vue.use(require('vue-google-adsense/dist/InArticleAdsense.min.js'));
   Vue.use(require('vue-google-adsense/dist/InFeedAdsense.min.js'));
 }
}VueAdsense Template :
<Adsense
    data-ad-client="ca-pub-XXXXXXXXXXXXXXXX"
    data-ad-slot="1234567890">
</Adsense>VueInArticleAdsense Template :
<InArticleAdsense
    data-ad-client="ca-pub-XXXXXXXXXXXXXXXX"
    data-ad-slot="1234567890">
</InArticleAdsense>VueInFeedAdsense Template :
<InFeedAdsense
    data-ad-layout-key="-fg+5n+6t-e7+r"
    data-ad-client="ca-pub-XXXXXXXXXXXXXXXX"
    data-ad-slot="1234567890">
</InFeedAdsense>import ScriptX from 'vue-scriptx'
app.use(ScriptX)
import Ads from 'vue-google-adsense'
app.use(Ads.AutoAdsense, { adClient: 'YOUR_GOOGLE_AD_CLIENT', isNewAdsCode: true })| Attribute | Type | Default | Description | 
|---|---|---|---|
| root-class | String | adswrapper | Class for fill in wrapper block | 
| ins-class | String | empty | Class for fill in instag | 
| ins-style | String | display:block; | Style for fill in instag | 
| data-ad-client | String | empty | Attribute data-ad-clientfrom adsense | 
| data-ad-slot | String | empty | Attribute data-ad-slotfrom adsense | 
| data-ad-layout-key | String | empty | Attribute data-ad-layout-keyfrom adsense | 
| data-ad-test | String | empty | Attribute data-ad-testfrom adsense | 
| data-ad-format | String | autofor Adsense Adsfluidfor InFeed and InArticle Ads | Attribute data-ad-formatfrom adsensePossible values are auto,horizontal,vertical,rectangleorfluid | 
| data-full-width-responsive | String ( yesorno) | no | Attribute data-full-width-responsivefrom adsense | 
| is-non-personalized-ads | String ( yesorno) | no | Props for request non-personalizedads, read more | 
| is-new-ads-code | String ( yesorno) | no | Use new Adsense code (per 19 july 2021), read more | 
| data-ad-region | String | empty | See PR #163 | 
Already used in production for these project :
- Blog-2.0
- Explore-Github
- Fire Jak
- Rumah Sakit Jakarta
- ChuckNorris
- Nuxt blog - Surmon.me
- Etc... // You can add the list here via pull request
We are using pnpm, please read the Installation section first.
# install dependencies
pnpm run bs
# serve with demo page
pnpm run dev:demo
# build for production
pnpm run build:demo
pnpm run build:lib- ๐ ๐ฎ๐ฉ Trakteer
- ๐ ๐ BuyMeACoffe
- ๐ ๐ Paypal
- ๐ ๐ Ko-Fi
Copyright ยฉ 2018 Built with โค๏ธ by Irfan Maulana